数据结构线性表多项式加减实验报告.docVIP

数据结构线性表多项式加减实验报告.doc

  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文档。上传文档
查看更多
数据结构线性表多项式加减实验报告

数据结构实验报告 实验名称: 实验一 ——线性表 日 期: 2013年10月28日 实验要求 实验目的 熟悉C++语言的基本编程方法,掌握集成编译环境的调试方法 学习指针、模板类、异常处理的使用 掌握线性表的操作的实现方法 学习使用线性表解决实际问题的能力 实验内容 利用线性表实现一个一元多项式Polynomial f(x) = a0 + a1x + a2x2 + a3x3 + … + anxn Polynomial的结点结构如下: struct term { float coef; //系数 int expn; //指数 }; 要求: 能够实现一元多项式的输入和输出 能够进行一元多项式相加 能够进行一元多项式相减 能够计算一元多项式在x处的值 能够计算一元多项式的导数(选作) 能够进行一元多项式相乘(选作) 编写测试main()函数测试线性表的正确性 2. 程序分析 考虑到数据结构的实现,因为多项式是线性结构因此选择线性表,而本次实验中涉及到多项式的加减,要进行节点的添加或者删除,用顺序表显然不能满足要求,而且由于不知道多项式的项数,很容易造成空间的浪费,当两个多项式指数相差很远时,操作要移动很多项,步骤很麻烦繁琐。综上,我选择了单链表,每个节点有三个部分,分别储存系数、指数、和指针,这样在计算加减或者指数不等时,只需要简单的摘连加链即可,而且不会造成空间的太多浪费。每次利用尾插法将结点插入基准多项式。 2.1 存储结构 本次实验采取的多项式加减算法是将一个多项式作为基准,把另一个多项式加到基准多项式中去,求和后的多项式仍然存储在第一个线性表中,因此用单链表的数据结构更为方便。 单链表存储结构 在本次实验中,因为形式的特殊性,每个节点如下图表示: 空链表 非空链表 其中每个结点前两个分别储存float型系数coef和int型指数expn,第三个作为指针指向下一个节点(不是最后一个结点时,否则为NUll) 2.2 关键算法分析 1、输入多项式 自然语言描述: 指定多项式的项数n 建立一个叫term的struct结构类型,用来储存指定多项式的系数和指数的数据。 设置一个term类型的结构数组ea[]。 按升幂次序逐项输入多项式各项的系数和指数并存入结构数组ea[]。 利用尾插法建立单链表,将数组ea[]中的数据分别赋给节点Node的coef域和exp域,最后一个节点指空。 伪代码: 输入项数n 输入ea结构数组各项数据 利用尾插法建立单链表 3.1 在堆中建立新结点 3.2 将数据写入到新结点中 Node-exp[i]=ea-exp[i]; Node-coef[i]=ea-coef[i]; 3.3 将新结点加入到链表中 3.4 修改尾指针 3.5 最后一个结点指为空 时间复杂度O(n),空间复杂度S(n) 2、输出多项式 自然语言描述: 得到链表的结点个数n 设置工作指针f指向头结点后一个节点 由于第一项前不需要加号,故单独输出第一项(f-coef)x^(f-exp) 之后移动f循环遍历剩余的节点,逐项输出+(f-coef)x^(f-exp) 伪代码描述: 1.term*f= first-next; 2.输出(f-coef)x^(f-exp) 3.循环n-1次 3.1 f=f-next; 3.2 输出+(f-coef)x^(f-exp) 时间复杂度O(n),空间复杂度S(1) 3、多项式相加 自然语言描述: 设有两个多项式链表A和B,设置工作指针p和q分别指向其第一项 若p-expq-exp,则结点p保留不变,p指向A链表的下一个结点继续比较。 若p-expq-exp,则结点q应为结果中的一个结点,将q结点加入到p结点之前,q结点指向下一个位置,继续比较。 若p-exp=q-exp,则p与q所指为同类项,则为以下两种情况: 合并的系数为0,则删除p结点 合并的系数不为0,将其重新赋予p结点 两结点合并后可删除q结点,并将p、q分别指向下一个位置继续比较 (a)若p已指空,q依然存在,则逐项将q复制至A链表的最后; (b)若q指空,则不需再进行操作。 当p、q均不存在,运算结束。 伪代码描述 初始化工作指针p和q,以及p结点的前驱结点指针p_prior; 若p和q都不为空,则循环如下操作: 2.1 若p-data.exp q-data.exp,则p_prior = p; p = p-next; 2.2 否则,若p-data.exp q-data.exp,则: 2.2.1 将q结点加入到A链表p结点之

文档评论(0)

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

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

1亿VIP精品文档

相关文档