设计函数求一元多项式的导数。
输入格式:以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过1000的整数)。数字间以空格分隔。
输出格式:以与输入相同的格式输出导数多项式非零项的系数和指数。数字间以空格分隔,但结尾不能有多余空格。
输入样例:3 4 -5 2 6 1 -2 0输出样例:
12 3 -10 1 6 0 //此题的系数的输出格式一定要整型!不然A不了!
#include <iostream> #include <deque> using namespace std; typedef struct { int Xi; int Zhi; }DuoX; deque<DuoX> v; int main() { DuoX d; int i; while(cin>>d.Xi>>d.Zhi) { v.push_back(d); } for(i = 0; i < v.size(); ++i) { if(v[i].Zhi == 0 || v[i].Xi == 0) { v.erase(v.begin()+i); i--; continue; } v[i].Xi *= v[i].Zhi; v[i].Zhi --; } if(v.size() == 0) cout<<"0 0"; while(v.size()) { if(v.size() == 1) { cout<<v.front().Xi<<" "<<v.front().Zhi; v.pop_front(); } else { cout<<v.front().Xi<<" "<<v.front().Zhi<<" "; v.pop_front(); } } cout<<endl; return 0; }