我有一个我无法弄清楚的作业。
我们有一个格式如下的文件:
5
4
100 500 250 300
1
700
3
300 150 175
2
920 680
8
20 10 15 25 50 30 19 23
第一行是拍卖的总数。
之后,每两行代表一次拍卖。
第一行是出价数量。下一行是实际出价。
例如,数字 4 表示有 4 个出价的拍卖 (100,500,250,300)。
我的任务是确定每次拍卖的最高出价。这是我到目前为止所得到的。任何帮助将不胜感激。
#include <stdio.h>
int main() {
FILE * ifp;
char filename[100];
printf("File name\n");
scanf("%s", &filename);
ifp = fopen (filename, "r");
if (ifp == NULL) {
printf("Error, File could not be opened.\n");
return 1;
}
int i, num_auctions, auction, j, bid, max;
fscanf(ifp, "%d", &num_auctions);
for(i=0; i<num_auctions; i++) {
fscanf(ifp, "%d", &auction);
if (bid > max)
max = bid;
for(j=0; j<auction; j++){
fscanf(ifp, "%d", &bid);
printf("%d\n", bid);
}
printf("%d\n", max);
}
fclose(ifp);
return 0;
}
最佳答案
这些是您的代码中的问题。
bid
和max
未初始化使用。解决方法是在声明时将它们设置为 0。if (bid > max)
检查位置错误。它只检查每次拍卖的最后出价。解决方法是将该检查移动到fscanf
之后的内部for
循环中。max
需要在每次拍卖后清除。解决方法是在外部for
循环的顶部将max
设置为 0。
关于C编程: Finding max in a file string,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40031811/