7-16 一元多项式求导(20 分)(有关while(scanf("%d",&n)!=EOF))

7-16 一元多项式求导(20 分)

设计函数求一元多项式的导数。

输入格式:

以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过1000的整数)。数字间以空格分隔。

输出格式:

以与输入相同的格式输出导数多项式非零项的系数和指数。数字间以空格分隔,但结尾不能有多余空格。

输入样例:

3 4 -5 2 6 1 -2 0

输出样例:

12 3 -10 1 6 0 

解题思路:1.一开始还以为这道题蛮简单的,刷刷刷就写了个用数组做的,然后有一个测试点运行超时

                  2.然后就换了一边输入一边输出,但是还是有个测试点:“无常数项的一般情况 ”通不过,然后在网上找了别人的代码

                    我发现他们都有写一句  while(scanf("%d",&n)!=EOF)  这丫什么鬼,然后又去网上找了

scanf的返回值由后面的参数决定

 

scanf("%d%d", &a, &b);

 

如果a和b都被成功读入,那么scanf的返回值就是2

 

如果只有a被成功读入,返回值为1

 

如果a和b都未被成功读入,返回值为0

 

如果遇到错误或遇到end of file,返回值为EOF

这句话主要解决

“测试输入包含若干测试实例。当N为0时,输入结束,该实例不被处理。”

                     好吧,其实还是有一些不懂,暂且先记着吧

 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 
 4 int main()
 5 {
 6     int xi,zi;  //系数,指数
 7     int flag=0;
 8     while(scanf("%d %d",&xi,&zi)!=EOF){
 9         if( zi ){
10            if( flag )
11                 printf(" ");  //如果不是第一个数就先输出一个空格
12            else
13                 flag =1;
14            printf("%d %d",xi*zi,zi-1);
15         }
16         else break;
17     }
18     if( flag==0 ){
19         printf("0 0");
20     }
21     return 0;
22 }

 

 

在这个国度中,必须不停地奔跑,才能使你保持在原地。如果想要寻求突破,就要以两倍现在速度奔跑!
原文地址:https://www.cnblogs.com/yuxiaoba/p/8365140.html