PAT B1010 一元多项式求导(C++)

PAT甲级目录 | PAT乙级目录

题目描述

设计函数求一元多项式的导数。(注:$x^n$( $n$ 为整数)的一阶导数为 $nx^{n-1}$ 。)

输入格式:

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

输出格式:

以与输入相同的格式输出导数多项式非零项的系数和指数。数字间以空格分隔,但结尾不能有多余空格。注意“零多项式”的指数和系数都是 0,但是表示为 0 0

输入样例:

1
3 4 -5 2 6 1 -2 0

输出样例:

1
12 3 -10 1 6 0

易错点:

  • 结果为 0 的时候要另外判断,输出 0 0

也许陌生的知识点

  • while(scanf("%d %d", &a, &b) != EOF){ }
    • 可用于判断输入是否结束,自己测试运行时可用 ctrl + z 作为输入结束,程序可识别

代码示例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <cstdio>
using namespace std;
int main(){
int a, b, S[1010][2], cnt = 0, print = 0;
while(scanf("%d %d", &a, &b) != EOF){ // 输入结束判断
S[cnt][0] = a * b;
S[cnt][1] = b - 1;
cnt ++;
}
for(int i = 0; i < cnt; i++){
if(S[i][1] >= 0){
if(i != 0) printf(" ");
printf("%d %d", S[i][0], S[i][1]);
print++;
}
}
if(print == 0) printf("0 0");
return 0;
}