PAT 1010 一元多项式求导
题目:
设计函数求一元多项式的导数。(注: x n x^n xn( n n n为整数)的一阶导数为 n x n − 1 nx^{n-1} nxn−1。)
输入格式:
以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过 1000 的整数)。数字间以空格分隔。
输出格式:
以与输入相同的格式输出导数多项式非零项的系数和指数。数字间以空格分隔,但结尾不能有多余空格。注意“零多项式”的指数和系数都是 0,但是表示为 0 0
。
输入样例:
3 4 -5 2 6 1 -2 0
输出样例:
12 3 -10 1 6 0
代码:
方法一:
#include <iostream>
#include <string>
#include <sstream>
#include <vector>
using namespace std;
int main()
{
string input;
int temp,temp1,temp2 = 0;
int len = 0;
stringstream ss;
vector<int> num;
vector<int> coefficients,grad;
vector<int> coefficients_next,grad_next;
getline(cin,input);
ss<<input;
while(ss>>input){
temp = stoi(input);
num.push_back(temp);
}
len = num.size();
for(int i = 0;i < len;++i){
if(i%2 == 0){
coefficients.push_back(num[i]);
}
else if(i%2 == 1){
grad.push_back(num[i]);
}
}
len = grad.size();
for(int i = 0;i < len;++i){
temp1 = coefficients[i]*grad[i];
temp2 = grad[i] - 1;
if(temp2 >= 0){
coefficients_next.push_back(temp1);
grad_next.push_back(temp2);
}
}
len = grad_next.size();
if(len >= 1){
for(int i = 0;i < len-1;++i){
cout<<coefficients_next[i]<<" "<<grad_next[i]<<" ";
}
cout<<coefficients_next[len-1]<<" "<<grad_next[len-1];
}
else cout<<0<<" "<<0;
return 0;
}
方法二:
#include<iostream>
using namespace std;
int main()
{
int a,b;
int x=1;
while(cin>>a>>b)
{
if(b==0)
break;
//用于输出" ",每隔一位输出一次
if(!x)//x取反
cout<<" ";
else
x=0;
cout<<a*b<<" "<<b-1;
}
if(x)
cout<<"0 0";
return 0;
}
解析:
简单的乘法以及减法
第一种代码:第一次做的时候想太多了,没有必要将数据存储下来.
第二种代码:按照两两一组,直接判断阶数输出.
同时第二种还有一个算法题常用的解决最后一位不包括空格和换行的方法,详见其关于x的if语句处.