- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
项目一 一元多项式的计算问题
1.1设计题目与要求
1.1.1设计题目
1)一元多项式计算
任务:能够按照指数降序排列建立并输出多项式;能够完成两个多项式的相加、相减,并将结果输入;
基本要求:在上交资料中请写明:存储结构、多项式相加的基本过程的算法(可以使用程序流程图) 、源程序、测试数据和结果、算法的时间复杂度、另外可以提出算法的改进方法;
本程序关键点是如何将输入的两个多项式相加、相减操作。
= 1 \* GB3 ①如何将输入的一元多项式按指数的降序排列
= 2 \* GB3 ②如何确定要输入的多项式的项数;
= 3 \* GB3 ③如何将输入的两个一元多项式显示出来。
= 4 \* GB3 ④如何将输入的两个一元多项式进行相加操作。
= 5 \* GB3 ⑤如何将输入的两个一元多项式进行相减操作。
本程序是通过链表实现一元多项式的相加减操作。
1.1.2、任务定义
此程序需要完成如下的要求:将多项式按照指数降序排列建立并输出,将两个一元多项式进行相加、相减操作,并将结果输入。
a: 输入多项式的项数并建立多项式;
b: 输出多项式,输出形式分别为浮点和整数序列,序列按指数升序排列;
c: 多项式a和b相加,建立多项式a+b;
d: 多项式a和b相减,建立多项式a-b。
e: 多项式的输出。
1.2 数据结构的选择和概要设计:
1.2.1数据结构的选用
A:基于链表中的节点可以动态生成的特点,以及链表可以灵活的添加或删除节点的数据结构,为了实现任意多项式的加法,减法,因此选择单链表的结构体,它有一个系数,指数,下一个指针3个元属;例如,图1中的两个线性链表分别表示一元多项式和一元多项式。从图中可见,每个结点表示多项式中的一项。
图1 多项式表的单链存储结构
B:本设计使用了以下数据结构:
typedef struct node{
int xs; /*系数*/
int zs; /*指数*/
struct node * next; /*next指针*/
}Dnode,* Dnodelist;
C:设计本程序需用到八个模块,用到以下八个子函数如下:
1.Dnodelist Creat_node(void) /*链表初始化*/
2.int Insert_node(Dnodelist D,int xs,int zs) /*插入函数*/
3.Dnodelist Creat_Dmeth(int length) /*创建多项式*/
4.Dnodelist Addresult(Dnodelist D1,Dnodelist D2) /*多项式相加*/
5.Dnodelist Subresult(Dnodelist D1,Dnodelist D2) /*多项式相减*/
6.Dnodelist select(Dnodelist D1,Dnodelist D2) /*选择函数*/
7void Show(Dnodelist D) /*显示(输出)函数*/
8void main()主程序模块调用链一元多项式的各种基本操作模块。
1.2.2 多项式的输入
先输入多项式的项数,采用尾插法的方式,输入多项式中一个项的系数和指数,就产生一个新的节点,建立起它的右指针,并用头节点指向它;
1.2.3 两个多项式的加法
“和多项式”链表中的结点无需另生成,而应该从两个多项式的链表中摘取。其运算规则如下:
假设指针A和B分别指向多项式a和多项式b中当前进行比较的某个结点,则比较两个结点中的指数项,有下列3种情况:
①指针A所指结点的指数值指针B所指结点的指数值,则应摘取A指针所指结点插入到“和多项式”链表中去;
②指针A所指结点的指数值指针B所指结点的指数值,则应摘取指针A所指结点插入到“和多项式”链表中去;
③指针A所指结点的指数值=指针B所指结点的指数值,则将两个结点中的系数相加,
若和数不为零,则修改A所指结点的系数值,同时释放B所指结点;反之,从多项式A的链表中删除相应结点,并释放指针A和B所指结点。例如,由图2中的两个链表表示的多项式相加得到的“和多项式”链表如图2所示,图中的长方框表示已被释放的结点。
图2 相加得到的和多项式????上述多项式的相加过程归并两个有序表的过程极其类似,不同之处仅在于,后者在比较数据元素时只出现两种情况。因此,多项式相加的过程也完全可以利用线性链表的基本操作来完成。
1.2.4流程图
(1)在主函数中调用函数进行多项式的输入、输出,运用选择语句来选择加
您可能关注的文档
- 审计学习题讲义.docx
- 2012注册安全工程师考试题库技术第六章(新)MicrosoftOfficeWord文档概述.doc
- 审计学作业(第5~14章)讲义.docx
- 审计这样说才对15年讲义.docx
- 审计作业之审计工作底稿讲义.docx
- 2013-2014年人教版八年级生物上册复习提纲概述.doc
- 肾透析功能说明讲义.docx
- 2013-2014学年八年级(下)期末生物模拟试卷概述.doc
- 肾小球肾炎讲义.docx
- 2013-2014学年度中考数学二轮专题复习:有理数的加减乘除以【含答案】概述.doc
- 吉林省长春市外国语学校2025-2026学年八年级上学期第一次月考数学试卷【含答案】.pdf
- 环境友好可再生型磁性复合材料:制备工艺、性能及多元应用探索.docx
- 题型03实验探究与设计(期中真题汇编,北京专用)九年级化学上学期【含答案】.pdf
- 江苏省常州市北郊初级中学2025~2026学年九年级上学期第一次月考化学试卷【含答案】.pdf
- 高血压与糖尿病的相关性与控制.pptx
- 替位掺杂对铁酸铋纳米材料磁性与介电性能的影响及机制研究.docx
- 出口退税政策调整:对铝工业的多维度影响与战略转型研究.docx
- 多维视角下中国运输服务贸易国际竞争力的剖析与提升策略.docx
- 江苏省常州市新北区2025-2026学年九年级上学期第一次月考化学练习卷【含答案】.pdf
- 虚拟家庭装修系统中实时渲染模块框架与特效的深度剖析与实践.docx
文档评论(0)