题目描述
一元nn次多项式可用如下的表达式表示:
其中,a_ix^iaixi称为ii次项,a_iai 称为ii次项的系数。给出一个一元多项式各项的次数和系数,请按照如下规定的格式要求输出该多项式:
-
多项式中自变量为xx,从左到右按照次数递减顺序给出多项式。
-
多项式中只包含系数不为00的项。
-
如果多项式nn次项系数为正,则多项式开头不出现“++”号,如果多项式nn次项系
数为负,则多项式以“-−”号开头。
4. 对于不是最高次的项,以“++”号或者“-−”号连接此项与前一项,分别表示此项
系数为正或者系数为负。紧跟一个正整数,表示此项系数的绝对值(如果一个高于00次的项,
其系数的绝对值为11,则无需输出 11)。如果xx的指数大于11,则接下来紧跟的指数部分的形
式为“x^bxb”,其中 bb为 xx的指数;如果 xx的指数为11,则接下来紧跟的指数部分形式为“xx”;
如果 xx 的指数为00,则仅需输出系数即可。
5. 多项式中,多项式的开头、结尾不含多余的空格。
输入输出格式
输入格式:
输入共有 22 行
第一行11 个整数,nn,表示一元多项式的次数。
第二行有 n+1n+1个整数,其中第ii个整数表示第n-i+1n−i+1 次项的系数,每两个整数之间用空格隔开。
输出格式:
输出共 11 行,按题目所述格式输出多项式。
输入输出样例
输入样例#1: 复制
5
100 -1 1 -3 0 10
输出样例#1: 复制
100x^5-x^4+x^3-3x^2+10
输入样例#2: 复制
3
-50 0 0 1
输出样例#2: 复制
-50x^3+1
说明
NOIP 2009 普及组 第一题
对于100%数据,0 \le n \le 1000≤n≤100,-100 \le−100≤系数\le 100≤100
#include <iostream>
#include <cmath>
using namespace std;
int main(){
int a,n;
cin>>n;
for(int i=n;i>=0;i--){
cin>>a;
if(a==0)
continue;
if(i!=n&&a>0)//第一项前面没+号
cout<<"+";
if(abs(a)>1)//常数1不写
cout<<a;//自带负号,但是-1不满足该if
if(a==-1)
cout<<"-";
if(i>1)
cout<<"x^"<<i;
if(i==1)
cout<<"x";
if(i==0 && abs(a)==1) //这个好致命啊 2x+ 9x- 等等
cout<<"1";
}
}
下面来自洛谷题解
以下题解仅供学习参考使用。
抄袭、复制题解,以达到刷AC率/AC数量或其他目的的行为,在洛谷是严格禁止的。
洛谷非常重视学术诚信。此类行为将会导致您成为作弊者。具体细则请查看洛谷社区规则。
#include<bits/stdc++.h>
using namespace std;
int main(){
int n,a;
cin>>n;
for(int i=n;i>=0;i--){
cin>>a;
if(a){ 判0系数
if(i!=n&&a>0)cout<<"+"; 根据正负、是否为最高此项决定加号
if(abs(a)>1||i==0)cout<<a; 输出系数(系数不为正负1或指数为0)
if(a==-1&&i)cout<<"-"; -1系数特判,常数项已特判
if(i>1)cout<<"x^"<<i; 二次及以上输出指数
if(i==1)cout<<"x"; 一次项
}
}
}
此输出一项流程应该是这样 1.系数为0?结束,否则继续;
2.是开头第一项?跳转至(4),否则继续;
3.系数为正?输出加号并继续,否则继续;
4.系数是±1?继续,否则跳转至6;
5.是常数项(只有数字没有字母)?继续,否则跳转至7;
6.输出系数并继续;
7.系数是-1?继续,否则跳转至10;
8.是常数项?跳转至10,否则继续;
9.输出负号并继续;
10.指数>1?继续,否则跳转至12;
11.输出"x^指数"并继续;
12.指数=1?输出"x"并结束,否则结束;
对每一项都按流程跑一遍就AC了
另外的题解,供你参考
做这道题挺不容易的,需要考虑很多种情况:
1、非第一项输出‘+’号。
2、系数为一不用输出系数(常数项除外!!!!!)。
3、系数为零不输出。
4、若多项式为零,需要输出‘0’!!!!!
#include<cstdio>
using namespace std;
int n,a[105];
int abs(int n)
{
return n>0?n:-n;
}
int main()
{
scanf("%d",&n);
for(int i=n;i>=0;i--)
scanf("%d",&a[i]);
bool flag=1;//判断多项式是否为零
for(int i=n;i>=0;i--)
{
if(a[i]==0)continue;
if(flag==0&&a[i]>0)printf("+");
if(a[i]<0)printf("-");
if(abs(a[i])!=1||i==0)printf("%d",abs(a[i]));
if(i==0)continue;
printf("x");
if(i==1)continue;
printf("^%d",i);
flag=0;
}
if(flag==1)printf("0");
printf("\n");
return 0;
}