#include<stdio.h> int main() { float h = 100; int n = 0; int i = 0; float ret = 0; float sum = 0; scanf("%d", &n); for (i = 0; i < n; i++) { sum += h; ret = h / 2; h = ret; } printf("the total of road is %f\n",sum); printf("the tenth is %f meter\n",ret); return 0; }
时间: 2024-04-01 18:37:45 浏览: 111
这段代码是一个简单的求高度为100米的球从100米高度自由落体,第n次反弹后总共走过的路程和第n次反弹的高度的程序。通过输入n的值,程序利用for循环进行n次反弹,每次反弹高度除以2,最后累加每次反弹的高度,得到总共走过的路程。同时,第n次反弹的高度也被计算出来,存储在变量ret中,最后输出总共走过的路程和第n次反弹的高度。
相关问题
用c写一个一直 ping 一个ip地址 如果ping不到就给ret值为1
以下是一个简单的 C 语言程序,可以一直 ping 一个 IP 地址,如果 ping 不通则返回 1:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <netinet/ip_icmp.h>
#include <netdb.h>
#define PACKET_SIZE 4096
#define MAX_WAIT_TIME 5
#define MAX_NO_PACKETS 3
struct packet
{
struct icmphdr hdr;
char msg[PACKET_SIZE-sizeof(struct icmphdr)];
};
unsigned short checksum(void *b, int len)
{
unsigned short *buf = (unsigned short *)b;
unsigned int sum = 0;
unsigned short result;
for (sum = 0; len > 1; len -= 2)
sum += *buf++;
if (len == 1)
sum += *(unsigned char*)buf;
sum = (sum >> 16) + (sum & 0xFFFF);
sum += (sum >> 16);
result = ~sum;
return result;
}
int ping(char *host)
{
struct hostent *hname;
struct sockaddr_in addr_ping;
int sockfd, i, len, flag = 1, flag_recv = 1;
struct packet pkt;
struct timeval tv_begin, tv_end, tv_interval;
float rtt = 0;
memset(&addr_ping, 0, sizeof(addr_ping));
addr_ping.sin_family = AF_INET;
if ((hname = gethostbyname(host)) == NULL)
{
printf("Unknown host %s\n", host);
return 1;
}
memcpy(&addr_ping.sin_addr, hname->h_addr, sizeof(addr_ping.sin_addr));
printf("PING %s (%s): %d bytes data in ICMP packets.\n", hname->h_name, inet_ntoa(addr_ping.sin_addr), (int)sizeof(struct packet));
if ((sockfd = socket(AF_INET, SOCK_RAW, IPPROTO_ICMP)) < 0)
{
printf("socket error\n");
return 1;
}
while (flag)
{
flag_recv = 1;
memset(&pkt, 0, sizeof(pkt));
pkt.hdr.type = ICMP_ECHO;
pkt.hdr.code = 0;
pkt.hdr.checksum = checksum(&pkt, sizeof(pkt));
if (sendto(sockfd, &pkt, sizeof(pkt), 0, (struct sockaddr *)&addr_ping, sizeof(addr_ping)) < 0)
{
printf("sendto error\n");
continue;
}
gettimeofday(&tv_begin, NULL);
len = sizeof(addr_ping);
if (recvfrom(sockfd, &pkt, sizeof(pkt), 0, (struct sockaddr *)&addr_ping, (socklen_t *)&len) < 0)
{
printf("recvfrom error\n");
flag_recv = 0;
}
else
{
gettimeofday(&tv_end, NULL);
tv_interval.tv_sec = tv_end.tv_sec - tv_begin.tv_sec;
tv_interval.tv_usec = tv_end.tv_usec - tv_begin.tv_usec;
rtt = tv_interval.tv_sec * 1000.0 + tv_interval.tv_usec / 1000.0;
printf("%d bytes from %s: icmp_seq=%u ttl=%d time=%.1f ms\n", sizeof(pkt), inet_ntoa(addr_ping.sin_addr), pkt.hdr.un.echo.sequence, pkt.hdr.un.echo.sequence, rtt);
flag_recv = 1;
}
sleep(1);
if (!flag_recv)
{
flag = 0;
printf("ping %s fail\n", host);
close(sockfd);
return 1;
}
if (i >= MAX_NO_PACKETS)
{
flag = 0;
}
}
close(sockfd);
return 0;
}
int main(int argc, char *argv[])
{
if (argc < 2)
{
printf("Usage: %s <hostname>\n", argv[0]);
return 1;
}
return ping(argv[1]);
}
```
注意:该程序需要在 Linux 环境下运行,并且需要 root 权限才能发送 ICMP 包。
用C语言完成,现在有32个dat文件要引用到程序中存放在一个数组中,有什么简洁的方式吗,以下是一个dat文件应用的例子float coeffs[128]
在C语言中,如果要将32个DAT文件的内容合并并存储在一个数组中,可以考虑使用动态内存分配和文件读取操作。由于每个DAT文件的结构未知(是否都是固定大小),这里提供一个通用的示例,假设所有DAT文件都是浮点数类型的,并且它们的总大小小于可用内存。
```c
#include <stdio.h>
#include <stdlib.h> // for malloc and free
// 假设每个DAT文件的数据都是一维浮点数组
typedef struct {
char filename[64];
float *data;
size_t dataSize; // DAT文件数据的实际大小
} DatFile;
// 动态加载单个DAT文件并返回指向其数据的指针
DatFile* loadDatFile(const char *filename) {
FILE *file = fopen(filename, "rb");
if (!file) {
printf("Error opening file: %s\n", filename);
return NULL;
}
fseek(file, 0, SEEK_END); // 获取文件长度
size_t fileSize = ftell(file);
rewind(file);
float *data = (float*)malloc(fileSize * sizeof(float));
fread(data, 1, fileSize, file);
fclose(file);
DatFile *ret = malloc(sizeof(DatFile));
ret->filename = filename;
ret->data = data;
ret->dataSize = fileSize;
return ret;
}
// 主函数处理所有DAT文件并将数据添加到一个大数组中
void processDatFiles(char **filenames, int numFiles, float** resultArray) {
*resultArray = (float*)malloc(32 * sizeof(float)); // 预估最大32个文件
for (int i = 0; i < numFiles; i++) {
DatFile *fileData = loadDatFile(filenames[i]);
if (fileData) {
memcpy(*resultArray + i * fileData->dataSize, fileData->data, fileData->dataSize);
free(fileData->data);
free(fileData);
}
}
}
int main() {
char filenames[] = {"file1.dat", "file2.dat", ... "file32.dat"}; // 32个文件名
int numFiles = sizeof(filenames) / sizeof(filenames[0]);
float *combinedData = NULL;
processDatFiles(&filenames[0], numFiles, &combinedData);
// 现在combinedData包含了所有32个文件的数据,可以根据需要进一步操作
...
// 使用完后别忘了释放内存
free(combinedData);
return 0;
}
```
阅读全文