C++一元多项式合并实验报告.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C一元多项式合并实验报告

实验二 一元多项式相加问题 本实验的目的是进一步熟练掌握应用链表处理实际问题的能力。 问题描述 一元多项式相加是通过键盘输入两个形如P0+P1X1+P2X2+···+PnXn的多项式,经过程序运算后在屏幕上输出它们的相加和。 二、数据结构设计 分析任意一元多项式的描述方法可知,一个一元多项式的每一个子项都由“系数—指数”两部分组成,所以可将它抽象成一个由“系数—指数对”构成线性表,由于对多项式中系数为0的子项可以不记录他的数值,对于这样的情况就不再付出存储空间来存放它了。基于这样的分析,可以采取一个带有头结点的单链表来表示一个一元多项式。具体数据结构定义为: typedef struct node { float ce; //系数域 float ex; //指数域 struct node *next; //指针域 }lnode,*linklist; 三功能(函数)设计 输入并建立多项式的功能模块 此模块要求按照指数递增的顺序和一定的输入格式输入各个系数不为0的子项的“系数—指数对”,输入一个子项建立一个相关的节点,当遇到输入结束标志时结束输入,而转去执行程序下面的部分。 屏幕提示: input ce ex and end with 0: ce=1 ex=2 ce=0 ex=0 //输入结束标志 input ce ex and end with 0: ce=2 ex=2 ce=0 ex=0 //输入结束标志 输入后程序将分别建立两个链表来描述两个一元多项式: A=X^2 B=2X^2 这两个多项式的相加的结果应该为: C=3X^2 多项式相加的功能模块 此模块根据在1中建立的两个多项式进行相加运算,并存放在以C为头指针的一个新建表中。可以采用以下方法进行设计: 开始时a,b分别指向A,B的开头,如果ab不为空,进行判断:如果a所指的结点的指数和b所指的结点的指数相同,将它们的系数相加做成C式中的一项,如果不一样则将小的一项加到C中。 if(a-ex==b-ex) //判断指数是否相等 {s-ce=a-ce+b-ce; if(s-ce!=0) s-ex=a-ex; else delete s; a=a-next; b=b-next; } 直到将所有的结点都处理一遍,得到合并之后的C式。 多项式显示的功能模块 此模块用于多项式的显示,程序可以使用文本界面,用“系数—指数对”的形式表达表达式,如: A=X^2+2X^3+3X^4+5X^6 B=2X^2+3X^3+5X^5+7X^9 C=3X^2+5X^3+3X^4+5X^5+5X^6+7X^9 界面设计 提示用户每一步输入操作的格式和限制。指导用户按照正确的格式输入数据。 编码实现 见源程序。 运行与测试 测试以下数据,比较结果: (1)(2x+5x8-3.1x11)+(7-5x8+11x9)=-3.1x11+11x9+2x+7 (2)(x+x3)+(-x-x3)=0 (3)(x+x2+x3)+0= x+x2+x3 2、指数递增的顺序输入多项式,验证程序的健壮性和容错性。 试验完成后的思考 通过本程序熟练掌握了应用链表处理问题的能力,增加了处理细节问题的经验,达到了实验目的。 通过在设计过程中的讨论和思考,对使用现有知识系统利用计算机来解决数学问题确立了信心,对链表的意义有了更深刻的理解,为今后的程序设计奠定了一定的心理基础和技术上的准备。 由于个人能力实在有限,程序中还有一些需要完善的地方,例如,程序不能做出对数据类型的判断;没有一个美观的图形界面;输入方式复杂,极易出错,等等等等。在今后的试验中要多多联系这方面的能力。 附:程序源代码 #includeiostream using namespace std; typedef struct node{ float ce; int ex; struct node *next; }lnode,*linklist; linklist creat() { linklist L; lnode *s,*r; float m; int n; L=r=NULL; coutinput ce ex end and with 0:endl; coutce=; cinm; coutex=; cinn; while(mn) //结束 { s=new lnode; s-ce=m; s-ex=n; if(L==NULL) L=s; else r-next=s; r=s; coutce= ; cinm; coutex= ;

文档评论(0)

qwd513620855 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档