洛谷P1067 多项式输出(模拟)
2024-08-23 19:50:46
题目描述
一元 n 次多项式可用如下的表达式表示:
其中,aixi称为 i 次项,ai 称为 i 次项的系数。给出一个一元多项式各项的次数和系数,请按照如下规定的格式要求输出该多项式:
1. 多项式中自变量为 x,从左到右按照次数递减顺序给出多项式。
2. 多项式中只包含系数不为 0 的项。
3. 如果多项式 n 次项系数为正,则多项式开头不出现“+”号,如果多项式 n 次项系
数为负,则多项式以“-”号开头。
4. 对于不是最高次的项,以“+”号或者“-”号连接此项与前一项,分别表示此项
系数为正或者系数为负。紧跟一个正整数,表示此项系数的绝对值(如果一个高于 0 次的项,
其系数的绝对值为 1,则无需输出 1)。如果 x 的指数大于 1,则接下来紧跟的指数部分的形
式为“x^b”,其中 b 为 x 的指数;如果 x 的指数为 1,则接下来紧跟的指数部分形式为“x”;
如果 x 的指数为 0,则仅需输出系数即可。
5. 多项式中,多项式的开头、结尾不含多余的空格。
输入输出格式
输入格式:
输入共有 2 行
第一行 1 个整数,n,表示一元多项式的次数。
第二行有 n+1 个整数,其中第 i 个整数表示第 n-i+1 次项的系数,每两个整数之间用空
格隔开。
输出格式:
输出共 1 行,按题目所述格式输出多项式。
输入输出样例
说明
NOIP 2009 普及组 第一题
对于100%数据,0<=n<=100,-100<=系数<=100
以后再也不想看见这种题了QWQ、、好恶心啊
难是不难,注意很多种特判
建议不要看我的代码了,特别鬼畜
#include<cstdio>
#include<algorithm>
#include<cstdlib>
const int MAXN=*1e6+;
using namespace std;
inline int read()
{
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
}
int main()
{
int N=read(),flag=;
for(int i=N;i>=;i--)
{
int x=read();
if(x==) continue; if(flag==&&x>) flag=;
else x>?printf("+"):printf("-"); flag=;
if(x!=&&x!=-) printf("%d",abs(x));
if((x==||x==-)&&(i==)) printf("%d",abs(x));
if(i!=&&i!=) printf("x^%d",i);
if(i==) printf("x");
} return ;
}
最新文章
- vertx verticle
- shell中三种引号的用法
- smartform
- [解决方案] pythonchallenge level 6
- [转]python问题:IndentationError:expected an indented block错误解决
- 怎么把多个GridView和Repeater导入到word或者excel中
- ExtJS笔记 Ext.Loader
- SAP财务常用数据源概览
- uva 437 hdu 1069
- 使用XmlReader读Xml
- - Shell - sort处理大文件(页 1) - ChinaUnix.net
- redis持久化和主从同步
- DOM对象,控制HTML元素
- Groovy与Java集成常见的坑
- Firemonkey的几个特色属性(一)
- #Leetcode# 725. Split Linked List in Parts
- JVM 详解
- 1.Variables-变量(Dart中文文档)
- Linux C Socket编程发送结构体、文件详解及实例
- leetcode Two Sum II - Input array is sorted <;面试常考题>;