难点:
Q:如何用0 0结束输入?
A:
第一种尝试:
while(scanf("%d",&n)!=0&&scanf("%d",&m)!=0){ ... }
这样会TLE
TLE原因并非算法有问题(20000个数快排可以拿下无需顾虑) 而是读不进去n和m
而且注意scanf自身有返回值 无法读入时返回值是-1
题外话 用scanf也可以判断文件结束:
while(scanf("%d, &n"==-1)
scanf 函数是有返回值的,它的返回值可以分成三种情况
1) 正整数,表示正确输入参数的个数。例如执行 scanf("%d %d", &a, &b);
如果用户输入"3 4",可以正确输入,返回2(正确输入了两个变量);
如果用户输入"3,4",可以正确输入a,无法输入b,返回1(正确输入了一个变量)。
2) 0,表示用户的输入不匹配,无法正确输入任何值。如上例,用户如果输入",3 4",返回0。
3) EOF,这是在stdio.h里面定义的常量(通常值为-1),表示输入流已经结束。在Windows下,用户按下CTRL+Z(会看到一个^Z字符)再按下回车(可能需要重复2次),就表示输入结束;Linux/Unix下使用CTRL+D表示输入结束。
第二种尝试:
do{ scanf("%d %d",&n,&m); ... }while(n!=0 && m!=0);
注意while后分号
这样解决了输入不进去的问题 只是对于输入0 0会输出一个多余的0(先计算再判断留下后患)
第三种尝试(Bingo!):
while(1){
scanf("%d %d",&n,&m); if(!n && !m)break;
... }
白书中的标程
while(scanf("%d %d",&n,&m)==2 && n && m){ ... }