- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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结点之
您可能关注的文档
最近下载
- 计算机视觉 第7章 摄像机成像模型.ppt VIP
- 2025年部编版新教材语文二年级上册第三单元教案设计.docx
- 宠物医院一例猫血栓诊治方案.pdf VIP
- 史铁生的课件.pptx VIP
- 2024-2025学年广东省深圳市南山育才集团九年级(上)期中语文试卷.doc VIP
- 北师大版七年级下册 第2章平行线 ---纸片翻折问题 专题练习(word版、含解析).docx VIP
- 2025-2026学年八年级数学上学期第一次月考01(江西专用,人教版2024八年级上册第十三章_第十四章)【含答案】.docx
- 介绍信 接洽函.docx VIP
- 2025年-2025秋形势与政策课件携手周边国家共创美好未来.pdf
- 第05讲 平行线中的翻折问题解题技巧(含解析)-2021-2022学年七年级数学下册常考点.pdf VIP
文档评论(0)