题目描述
输入两个整数a和b,计算a+b的和
*注意此题是多组测试数据
输入
输入两个整数A和B
A,B均范围不超过2^10
输出
求A+B
样例输入
1 1
10 20
样例输出
2
30
#include <stdio.h>
int main(){
/* int的大致范围为1^10, 当取值都为最大值得时候就会发生溢出*/
int a,b;
while (scanf("%d%d",&a,&b)!= EOF)
{
/* 列入a=b=1^10 */
printf("%d\n",a+b);
}
/* 所以应该使用double,但是在网站中int却通过了 */
// float a,b;
// while ( scanf("%f%f",&a,&b)!= EOF)
// {
// printf("%.f\n",a+b);
// }
return 0;
}
总结注意:
为什么用while(1)或者while(true) 运行显示超出限额?
解答:
1.首先需要了解scanf()的返回值:
【注意】scanf函数的返回值是重点,必须理解。
scanf()函数返回值分为2种:
(1)返回一个正整数。表示正确输入参数的个数。
列如: scanf("%d %d",&a,&b),这个调用返回的值在用户输入1 2时,返回的是2,如果用户输入的是1 b,那么返回值为1,如果输入的是a b,那么返回的是0。
**那么问题一:
  刚刚用了这个例子,发现输入字母时会导致一直无限输出0?
#include <stdio.h>
int main(void) {
int x = 0;
while (1){
x = scanf("%d",&x);
printf("%d",x);
}
return 0;
}
仔细分析一下,就知道原因为何:
scanf这里要求输入参数为数字,输入字母会导致赋值失败,因此scanf返回值一直为0,也就导致输出0。注意:CTRL+c 终止循环!
至于为什么一直输出0是因为scanf对于接受失败的数据会送回stdin缓冲区,之前输入的字母会一直存在。在这个死循环中,scanf一遍遍读缓冲区的字母,也就会一直输出已一大串0。要想像输入数字那样可以循环输入,必须清除掉缓冲区的数据:setbuf(stdin,NULL);,这个语句加到scanf后面,如下所示:
#include <stdio.h>
int main() {
int x = 0;
while (1){
x = scanf("%d",&x);
setbuf(stdin,NULL);
printf("%d",x);
}
return 0;
}
scanf与getchar函数区别很大,使用时应小心谨慎。
(3)返回-1。表示输入流已经结束。在Windows下,按ctrl+z+回车(但有时会有些问题);Linux/Unix下使用CTRL+D表示输入结束。遇到错误或遇到end of file,返回值为-1。
这下大家就明白了吧!为什么用的不是while(1/true)
EOF本身就是一个-1的常量! 通过宏定义起了一个别名而已!
为什么叫EOF是因为文件末尾的英文翻译过来是End of File,因此取前三个字母就是EOF了!所以EOF通常用来表示已经到达文件末尾的意思。
那么相应的,在ACM或蓝桥杯等程序竞赛中,大家在经常会看到类似while(scanf("%d",&a)!=EOF)这样的代码的时候也就明白什么意思了吧!
很明显,是通过判断scanf的返回值与-1相比作为while的循环条件,不断的接收用户从键盘输入的值来达到效果。网站不会像我们一样在想终止时使用ctrl+c,所以我们通过判断缓冲区是否还用数据来判断!
题目来源:https://www.dotcpp.com/