最近在使用PAT与Codeup写程序玩,发现这两者的OJ方式不同。
PAT是单点测试,即输入一组测试用例即可输出结果,
而Codeup是多点测试,即输入所有测试用例后才会输出所有输出结果。
在这里写两个最简单的a+b求和小程序来说明二者的区别:
单点测试:
int main(){
int a,b;
scanf("%d%d",&a,&b);
printf("%d",a+b);
return 0;
}
程序只会读入前两位输入值,即2和3,对于后面两位则完全忽视,这是由 scanf("%d%d",&a,&b);决定的。
再看多点测试:
int main(){
int a,b;
while(scanf("%d%d",&a,&b)!=EOF){
printf("%d\n",a+b);
}
return 0;
}
同样的输入2 3 4 5 多点测试会输出两个和5 9,这是由while(scanf("%d%d",&a,&b)!=EOF)这行代码来决定的。
因为scanf函数是有其返回值的,我们经常也能在编译器中得到未处理scanf返回值的警告,但我们往往选择忽略。
scanf函数的返回值是其成功读入参数的个数,而当读取完最后一个参数时,scanf继续读取就会读取失败,此时会返回-1,在C语言中我们使用EOF来代表-1(当然直接使用-1也是没有问题的),知道这点后,上述代码就很好理解了,一个简单的while判定,此处不再赘述。