我目前正在编写一个程序,从文本文件中读取2个数字的数字并将其打印出来。我想稍后使用这些数字来确定GCD,但我必须能够先从文件中扫描它们。文本文件如下所示:
24 72
25 50
31 89
...
在第一行中的每个数字和第二行中的每个数字之间按下Tab键。
到目前为止,我已经提出了这个问题(注释掉的部分用于确定GCD):
/*
File name: euclid.cpp
This program find the largest common multiple of two numbers using the Euclid method.
*/
#include <stdio.h>
#include "genlib.h"
#include "simpio.h"
int main()
{
FILE *input;
long num1=0, num2=0, orinum2=0, rem=0, gcd=0;
int i=0, size=0;
char temp;
input=fopen("Euclid.txt", "r");
while((temp=getc(input))!=EOF)
{
if(temp=='\n') size++;
}
size++;
while(i<size)
{
fscanf(input, "%d\t%d%[^\n]", &num1, &num2);
printf("%d\t%d\n", num1, num2);
orinum2=num2;
/* while (true)
{
rem=num1%num2;
if (rem==0)
{
gcd=num2; break;
}
else
{
num1=num2;
num2=rem;
}
}
printf("The GCD of %d and %d is %d.\n", num1, orinum2, gcd);
*/ i++;
}
fclose(input);
}
我检查过的每一个网页和资源都表明这应该有效,但由于某种原因,它不是。
答案 0 :(得分:0)
fscanf将“返回成功匹配并分配的输入项目数”:
#include <stdio.h>
int main()
{
FILE *input = fopen("input.txt", "r"); ;
int num1, num2;
while(fscanf(input, "%d %d", &num1, &num2) > 0)
printf("%d\t%d\n", num1, num2);
fclose(input);
}
模式(“%d%d”)将匹配并分配两个整数,由任意数量的whitespace characters分隔。
空格字符包括标签(\ t)和换行符(\ n)。