1010 一元多项式求导 (25 分)——测试点2

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

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

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

输入样例:
3 4 -5 2 6 1 -2 0
输出样例:
12 3 -10 1 6 0
题目链接

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
#include <map>
using namespace std;
int main() {
map<int, int> n;
int i, j;
int w = 0;
while (cin >> i) {
cin >> j;
if (j == 0) {
if (i == 0 || w == 0) {
if (w++) cout << " ";
cout << 0 << " " << 0;
}
return 0;
} else {
if (w++) cout << " ";
cout << i * j << " " << j - 1;
}
}
}

测试点2一开始没过,发现是输入数据为单独的5 0时应该输出0 0但是没输出了,所以应该在j=0(指数等于0)是判断一下是否是第一次输入,如果是则还是输出0 0 (如果不是第一次输入就不输出了)。