我有一个任务,在那里我实现了二进制搜索和线性搜索。“硬”部分已经完成,这两种方法都得到了实现和工作。我的教授想让我们测试有大量整数的数组。他给了我们一个.in文件,它输入了他想要的样式,而我正在尝试使用freopen来读取这个文件。
int main(int argc, const char * argv[]) {
freopen("input.in", "r", stdin); // <-----
int n , s;
scanf("%d %d", &n, &s);
int myAr[n];
int i = 0;
while (i < n) {
scanf("%d",&myAr[i]);
i++;
}
int myAr2[s];
int j = 0;
while (j < s) {
scanf("%d",&myAr2[j]);
j++;
}
...该文件从一行中的2个数字、列表中的元素数和第一个列表中要查找的元素数开始。
然后,它读取列表1中所有数字的一行,然后下一行读取列表2中的所有数字。
我不能自由地()正常工作,我想知道外面有没有什么建议。
示例input.in文件:
10 2
2 4 6 7 9 10 24 26 29 33
26 35我的代码后来会告诉我,找到了26,而没有找到35。我的主要问题是在main中读取输入文件,而不是在终端中手动输入。请帮帮忙。
发布于 2015-03-17 08:06:59
我简单地使用input.in文件读取fscanf()文件中的所有整数。
这是我的密码。
int j;
FILE *fp;
fp = fopen("input.in", "r");
while( fscanf(fp,"%d",&j) > 0 )
{
printf("%d\n", j);
}
fclose(fp);产出是。

https://stackoverflow.com/questions/29092299
复制相似问题