栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

多项式加法(5分)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

多项式加法(5分)

程序设计入门——C语言_中国大学MOOC(慕课) (icourse163.org)

code1:
#include
#include

int main(){
	int a[101]={0};
	int i,mi=0,xi,cnt=0,max=0,nax=0,flag=0;
	while(1){
		scanf("%d %d",&mi,&xi);
		a[mi]+=xi;
		if(max=0;i--){         
		if(a[i]!=0&&nax=0;i--){
		if(a[i]!=0){
			flag=1;
			if(i==nax){
				if(a[i]==1||a[i]==-1){
					if(i==0) printf("%d",a[i]);
					else if(i==1) {
						if(a[i]==1) printf("x");
						if(a[i]==-1) printf("-x");
					}
					else{
						if(a[i]==1) printf("x%d",i);
						if(a[i]==-1) printf("-x%d",i);
					} 
				} 
				else{
					if(i==0) printf("%d",a[i]);
					else if(i==1) printf("%dx",a[i]);
					else printf("%dx%d",a[i],i);
				}
			} 
			else if(i==0) printf("%+d",a[i]);
			else if(i==1){
				if(a[i]==1) printf("+x");
				else if(a[i]==-1) printf("-x");
				else printf("%+dx",a[i]);
			}
			else{
				if(a[i]==1) printf("+x%d",i);
				else if(a[i]==-1) printf("-x%d",i);
				else printf("%+dx%d",a[i],i);
			} 
		}
	}
	if(flag==0) printf("0");
	return 0;
}
code2: 
#include
#include
#include
int main(){
	int a[101]={0};
	int i,mi=0,xi,cnt=0,max=0,nax=0,flag=0;
	while(1){
		scanf("%d %d",&mi,&xi);
		a[mi]+=xi;
		if(max=0;i--){         
		if(a[i]!=0&&nax=0;i--){
		if(a[i]!=0){
			flag=1;
			if(a[i]<0) printf("-");	
			if(a[i]>0&&cnt) printf("+");	
			
			if(i==0) {
				printf("%d",abs(a[i]));
				cnt++;
			}
			if(i==1&&abs(a[i])==1){
				printf("x");
				cnt++;
			}
			if(i==1&&abs(a[i])!=1){
				printf("%dx",abs(a[i]));
				cnt++;
			}
			if(i!=0&&i!=1&&abs(a[i])==1){
				printf("x%d",i);
				cnt++;
			}
			if(i!=0&&i!=1&&abs(a[i])!=1){
				printf("%dx%d",abs(a[i]),i);
				cnt++;
			}
		}
	}
	if(flag==0) printf("0");
	return 0;
}
总结: code1

吐槽一下题目,没有交代清楚幂次为1的时候是否还输出幂次(虽然例子里显示没有),也没有说明当系数为1的时候是否输出系数(应该是不输出),耽误时间……

当幂次最大的时候(正系数前不加+号),考虑①系数为1或-1②其他(如3x2)。其中①又考虑三种情况:幂次为0(如1或-1),幂次为1或-1(如x或-x),其他(x3或-x3);其中②也要相应考虑这三种情况。

当幂次为1的时候,考虑两种情况:①系数为1或-1②其他。

当幂次为0的时候,直接输出系数

其他情况(幂次不为最大,0或1),最普通情况。

总之要考虑,幂次和系数的各种不同情况

code2

把code1简化了一下:把符号的判断单独提取出来,后面都输出系数的绝对值;其他的一共有5种情况(a为常数):a,x,ax,xa,axa;

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/433385.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号