使用c语言编写程序:已知dat1.dat存放了一系列整型数据。 要求: 1)用dat1.dat中的前100个数据给数组int a[100]赋值,并在屏幕上输出(每行10个元素)。 2)使用函数 double isaver(int *p,int num) { } 求数组a中所有数组元素平均值。 3)把该函数放在头文件ISaver.h中以便在主函数中调用该函数。把所有小于平均值的数组元素(每行10个元素)和小于平均值的数组元素个数输出出来。(在屏幕上和数据文件d:\dat6.dat中同时输出)
时间: 2023-12-10 16:37:10 浏览: 81
c代码-12、/*用do...while语句计算1到n的累乘之积,即计算n!*/
以下是代码实现:
ISaver.h头文件:
```c
#ifndef ISaver_h
#define ISaver_h
double isaver(int *p, int num);
#endif /* ISaver_h */
```
main.c程序:
```c
#include <stdio.h>
#include "ISaver.h"
int main() {
FILE *fp1, *fp2;
int a[100];
double average;
int count = 0;
// 打开文件
fp1 = fopen("dat1.dat", "rb");
fp2 = fopen("dat6.dat", "wb");
// 读取前100个数据
fread(a, sizeof(int), 100, fp1);
// 输出数组
printf("数组a:\n");
for (int i = 0; i < 100; i++) {
printf("%d ", a[i]);
if ((i + 1) % 10 == 0) {
printf("\n");
}
}
// 求平均值
average = isaver(a, 100);
// 输出小于平均值的元素
printf("\n小于平均值的元素:\n");
for (int i = 0; i < 100; i++) {
if (a[i] < average) {
printf("%d ", a[i]);
fprintf(fp2, "%d ", a[i]); // 写入文件
count++;
if (count % 10 == 0) {
printf("\n");
fprintf(fp2, "\n"); // 写入文件
}
}
}
// 输出小于平均值的元素个数
printf("\n小于平均值的元素个数:%d\n", count);
fprintf(fp2, "小于平均值的元素个数:%d\n", count); // 写入文件
// 关闭文件
fclose(fp1);
fclose(fp2);
return 0;
}
double isaver(int *p, int num) {
double sum = 0;
for (int i = 0; i < num; i++) {
sum += p[i];
}
return sum / num;
}
```
注意事项:
- 读取二进制文件需要使用`fread`函数,写入二进制文件需要使用`fwrite`函数;
- 在写入文件时,需要注意格式和换行符的使用;
- 头文件中只需要声明函数,不需要实现函数;
- 需要在主函数中包含头文件。
阅读全文