我正在尝试编写一个程序,从stdin读取整数并打印它们的gcd。如果两个整数都是素数,我打印"prime"
。在结束程序打印到stderr
-"DONE"
之前。当用户输入错误的数据时,我想打印到stderr
-"ERROR"
。所以我写了这个代码:
#include "stdio.h"
#include "nd.h"
#include "nsd.h"
int main() {
int in1, in2;
int tmp;
while (1) {
tmp = scanf("%d %d", &in1, &in2);
if (tmp == EOF) {
fprintf(stderr, "DONEn");
break;
}
if (tmp != 2) {
fprintf(stderr, "ERRORn");
} else if ((nd(in1) == 1) && (nd(in2) == 1)) printf("primen");
// nd(int a) return 1 when a is prime
else printf("%dn", gcd(in1, in2));
}
return 0;
}
"ERROR"
之后我想继续工作。但它不起作用,我尝试在fprintf(stderr, "ERRORn");
之后添加continue;
,但它也不起作用。所以,我想:
- program run
5 10
5
1 3
prime
1 0.9
error
// not break here!
10 2
2
...
//EOF
DONE
- program stop
除了"ERROR"
,一切都是工作,我有这个:
- program run
5 0.9
ERROR
ERROR
ERROR
ERROR
...
//never stop
我知道在循环中这是正确的工作。我的问题是,我必须改变什么才能从"我拥有的"转变为"我想要的"。
scanf()
在处理意外输入时遇到问题。相反,使用fgets()
读取行
char buf[100];
if (fgets(buf, sizeof buf, stdin) == NULL) {
fprintf(stderr, "DONEn");
break;
}
if (sscanf(buf, "%d%d", &in1, &in2) != 2) {
fprintf(stderr, "ERRORn");
} else if ((nd(in1) == 1) && (nd(in2) == 1)) {
printf("primen");
} else {
printf("%dn", gcd(in1, in2));
}
修改了代码以查找行上的额外文本。
// if (sscanf(buf, "%d%d", &in1, &in2) != 2) {
// fprintf(stderr, "ERRORn");
int n = 0;
if (sscanf(buf, "%d%d %n", &in1, &in2, &n) != 2 || buf[n]) {
fprintf(stderr, "ERRORn");
} ...