poj 1555 Polynomial Showdown 模拟

//poj 1555
//sep9
#include <iostream>
using namespace std;
char s[10024];
int a[10024];

int main()
{
	while(gets(s)){
		int cnt=0;
		for(int i=0;s[i]!='\0';){
			int p=1;
			while(!(s[i]<='9'&&s[i]>='0')){
				if(s[i]=='-') 
					p=-1;
				++i;
			}
			int x=0;
			while(s[i]<='9'&&s[i]>='0')
				x=x*10+s[i]-'0',++i;
			x*=p;
			a[cnt++]=x;
		}
		int i;
		for(i=0;i<cnt;++i)
			if(a[i])
				break;
		if(i==cnt){
			puts("0");
			continue;
		}
		int first=0;
		for(int i=0;i<cnt;++i)
			if(a[i]){
				int e=cnt-i-1;
				if(first==0){
					first=1;
					if(a[i]<0){
						if(a[i]==-1)
							printf("-");
						else
							printf("%d",a[i]);
					}else{
						if(a[i]!=1)
							printf("%d",a[i]);
					}
				}else{
					if(a[i]<0){
						if(a[i]==-1)
							printf(" - ");
						else
							printf(" - %d",abs(a[i]));
					}else{
						if(a[i]==1)
							printf(" + ");
						else
							printf(" + %d",a[i]); 
					}					
				}
				if(e>1)
					printf("x^%d",e);
				else if(e==1)
					printf("x");	
				else if(e==0&&abs(a[i])==1)
					printf("1");
					
			}	
			puts("");	
	}
	return 0;	
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值