设计函数求一元多项式的导数。(注:xn(n为整数)的一阶导数为n*xn-1。)
输入格式:以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过1000的整数)。数字间以空格分隔。
输出格式:以与输入相同的格式输出导数多项式非零项的系数和指数。数字间以空格分隔,但结尾不能有多余空格。注意“零多项式”的指数和系数都是0,但是表示为“0 0”。
输入样例:3 4 -5 2 6 1 -2 0输出样例:
12 3 -10 1 6 0思路:注意结果可能是0多项式,例如输入 2 0,就需要输出 0 0
#include <iostream>
#include <vector>
#include <algorithm>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <cstring>
using namespace std;
#define MAX_STR_LENS 200
int main()
{
char str[MAX_STR_LENS] = {0};
char *token = NULL;
vector<int> vecNums; //´æ·ÅÊý¾Ý
int data = 0, i = 0;
int xishu = 0, zhishu = 0, counts = 0;
gets(str);
token = strtok(str," ");
while(token != NULL)
{
data = atoi(token);
vecNums.push_back(data);
token = strtok(NULL," ");
}
for(i = 0; i < vecNums.size(); i = i + 2)
{
if (vecNums[i+1] != 0)
{
xishu = vecNums[i] * vecNums[i + 1];
zhishu = vecNums[i + 1] - 1;
counts++;
if(i == 0)
{
cout << xishu << " " << zhishu;
}
else
{
cout << " " << xishu << " " << zhishu;
}
}
}
/* 注意结果有可能是0多项式 */
if(counts == 0)
{
cout << "0 0";
}
cout << endl;
}