数据结构实验报告-一元多项式
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数据结构课程设计报告
课题: 一元多项式
姓名:XX
学号:************
专业班级:XXXX
指导教师:XXXX
设计时间:2015年12月30日星期三评阅意见:
评定成绩:
指导老师签名:
年月日
目录
一、任务目标 (3)
二、概要设计 (4)
三、详细设计 (6)
四、调试分析 (8)
五、源程序代码 (8)
六、程序运行效果图与说明 (15)
七、本次实验小结 (16)
八、参考文献 (16)
一丶任务目标
分析(1) a.能够按照指数降序排列建立并输出多项式
b.能够完成两个多项式的相加,相减,并将结果输入
要求:程序所能达到的功能:
a.实现一元多项式的输入;
b.实现一元多项式的输出;
c.计算两个一元多项式的和并输出结果;
d.计算两个一元多项式的差并输出结果;
除任务要求外新增乘法:
计算两个一元多项式的乘积并输出结果
(2)输入的形式和输入值的范围:
输入要求:分行输入,每行输入一项,先输入多项式的指数,再输入多项式的系数,以0 0为结束标志,结束一个多项式的输入。
输入形式:
2 3
-1 2
3 0
1 2
0 0
输入值的范围:系数为int型,指数为float型
(3)输出的形式:
第一行输出多项式1;
第二行输出多项式2;
第三行输出多项式1与多项式2相加的结果多项式;
第四行输出多项式1与多项式2相减的结果多项式;
第五行输出多项式1与多项式2相乘的结果多项式
二、概要设计
程序实现
a. 功能:将要进行运算的二项式输入输出;
b. 数据流入:要输入的二项式的系数与指数;
c. 数据流出:合并同类项后的二项式;
d. 程序流程图:二项式输入流程图;
e. 测试要点:输入的二项式是否正确,若输入错误则重新输入。
流程图:
三、详细设计
(1):存储结构
一元多项式的表示在计算机内可以用链表来表示,为了节省存储空间,只存储多项式中系数非零的项。链表中的每一个结点存放多项式的一个系数非零项,它包含三个域,分别存放该项的系数、指数以及指向下一个多项式项结点的指针。创建一元多项式链表,对一元多项式的运算中会出现的各种可能情况进行分析,实现一元多项式的相加、相减操作。
(2):数据链表
由于采用链表的方法,我们可以建立3条链;一条用于存放多项式HA,一条用于存放多项式HB,还有一条用于存放新形成的HC。此外,我们的程序应具备以下几个功能:建立链表,撤销链表,打印链表,按要求插入一个新的结点,复制链表;为了使上面程序结构分析进一步细化,为了使程序结构更加清晰,我们可以把上面的内容都编写成函数形式。
1、建立链表
该程序建立链表的函数与大多数建立链表的操作基本一致,但是由于实体是一元多项式的关系。我们更希望,在处理客户输入的数据的同时,能对数据进行适当的处理。也就是数学上所说的,“对一元多项式进行化简,并按照降幂排序。”由于在前面的练习中,我们得知,在链表中插入一个结点的函数,具有对链表的成员进行排序与合并的功能。如此一来,我们可以巧妙地处理,在建立链表的同时,调用”在链表中插入一个结点的函数”,对新建立的链表进行化简。
该函数的算法描述如下;
声明指针变量,并作为头指针的指针变量赋初值NULL;
创建一个新的结点,并输入链表的信息;
若输入的系数值与函数值同不为0时,调用”在链表中插入一个结点的insert函数”,将结点插入链表中;(注:这里建立链表的函数与以往的不同,我们是通过假想有一条空链,不断地调用insert函数来实现建立链表的功能。简言之;链表中成员的链接全都靠insert函数来实现,而该函数仅仅是不断地提供建立链表所要的数据罢了。)
若还要继续插入结点,转到步骤2继续进行;
否则,程序结束,把头指针返回主程序。
2、撤销链表
撤销链表是为了把链表所占用的地址回收起来,防止造成浪费。我们该程序可以采用从链表的始端逐步销去结点。在这个过程中,我们需要链表的头地址作为形式参数,还需要建立一个指针用来指向新头地址。
该函数的算法描述如下:
指针变量;并把头地址指针赋给新指针变量;
把头地址指针指向下一个结点;
删除新指针变量;
若还要继续删除结点,转到步骤1继续执行;
否则,结束程序。
3、按要求插入一个新的结点
由于前面的建立链表的creat函数,调用了该函数,所以我们这个函数的设计思想也明朗多了,由于建立的链表是有序的,并且需要合并指数相同的结点,所以要新结点需要按指数值降幂的顺序插入链表中。判断链表是否为空,如果为
空则直接插入即可;否则按照要插入结点指数值的大小在链表中寻找他要插入的位置,对于插入位置有第一个节点、最后一个结点和链表中间这三种情况分别进行处理。
函数的形式参数:链表的头地址,指向要插入结点的指针;
返回结果:插入结点后新链表的头地址。
该函数的算法描述如下:
声明指针变量并令它指向连头结点;
判断指向要插入结点的指针是否为空;
如果是,则不需要插入新结点,直接返回头地址,程序结束;
否则再判断链表是否为空;
如果是,则直接插入结点,然后返回链表的头地址,程序结束;
否则,在链表中寻找待插入结点的插入位置:
1,若链表中存在着与“插入的结点”的指数相同的情况,我们依然插入链中,只是把该结点的系数修改为”0”,把链中的结点系数修改为”两系数之和”。(为了方便,我们并没有把结点进行删除的操作,只是在输出的操作里加入权限设置。)
2,若链表中不存在着与“插入的结点”的指数相同的情况,我们正常地插入链中。
返回插入结点后链表的头地址,程序结束。
4、主函数
主函数主要负责输出界面的指引语句,并合理地调用各个函数,还要有适当的循环操作以及停止循环的语句,以致可以方便地达到合并两个一元多项式的