本文主要是介绍2009NOIP普及组真题 1. 多项式输出,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
线上OJ:
一本通传送门:
核心思想:
逐一读入,逐一处理
step1、先输出符号
如果a小于0,则不管在哪个位置,都要输出负号;
如果a大于0,则除了最高次幂,其他都输出+号
step2、再输出abs不等于1的数
step3、再输出abs为1,且a为常数项的数
step4、最后处理x的t次幂
如果t大于1,则输出 x t x^t xt
如果t等于1,则输出 x
本题中没有 t 小于1的情况
题解代码:
#include <bits/stdc++.h>using namespace std;
int n, a;/*
step1、先输出符号
step2、再输出abs不等于1的数
step3、再输出abs为1,且a为常数项的数
step4、最后处理x次幂
*/
void prt(int a, int t)
{if(a == 0) return;// step1if(a < 0) printf("-"); // 如果a小于0,则不管在哪个位置,都要输出负号else if(t != n) printf("+"); // 如果a大于0,则除了最高次幂,其他都输出+号if(abs(a) != 1) printf("%d", abs(a)); // step2:如果是 1,则不需要输出,反之需要输出if(abs(a) == 1 && t == 0) printf("1");// step3:如果 1是常数项,则输出if(t > 1) printf("x^%d", t); // step4: 处理x次幂else if(t == 1) printf("x");return;
}int main()
{scanf("%d", &n);int t = n; do{scanf("%d", &a); // 读入后依次处理prt(a, t);}while(t--);return 0;
}
这篇关于2009NOIP普及组真题 1. 多项式输出的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!