




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、成绩 南京工程学院课程设计说明书(论文)题 目 一元多项式计算 课 程 名 称 数据结构 院(系、部、中心) 通信工程 专 业 计算机通信 班 级 算通111 学 生 姓 名 余丹红 学 号 208110410 设 计 地 点 信息楼322 指 导 教 师 郝慧珍 设计起止时间:2012年12月 17日至2012 年12月18日目 录1设计目标12总体设计121数据结构描述与定义122模块设计23测试结果与分析114课程设计总结13参考文献:15附录a: 源程序清单151 设计目标通过课程设计,达到理论与实际应用相结合,提高学生组织数据及编写大型程序的能力,使学生能够根据数据对象的特性,掌握数
2、据组织、算法设计、算法性能分析的方法,并培养良好的程序设计能力。本程序是利用单链表来表示一元多项式然后实现各项指数和系数的输入,进行多项式建立,并以多项式的形式输出,实现多项式的相加,相减和多项式的相乘这三种运算。2总体设计21数据结构描述与定义一元多项式定义系数和指数结构如下: coefexpnnextcoef域-存放结点的系数值expn域-存放结点的指数值next域-存放结点的直接后继的地址(位置)的指针域(链域)定义多项式的结构为线性链表的存储结构,每个结点包含三个元素:系数coef,指数expn和指向下一个结点的指针*next。通过指针,我们就可以把多个单项式连接起来,形式一个多项式,
3、需要说明的是从广义的角度讲,单项式也是一个多项式。基于以上的分析,我们定义多项式的数据结构为如下结构体形式:typedef struct polynomial float coef; /系数 int expn; /指数 struct polynomial *next; /下一个指针*polyn,polynomial; /polyn结构体变量名22模块设计从实现多项式式运算过程的角度来分析,至少需要这样一些子功能模块。 多项式创建功能 多项式销毁功能 多项式输出功能 多项式的相加功能 多项式的相减功能 多项式的相乘功能定义并调用的函数有:void insert(polyn p,polyn h);
4、/将结点p插入链表hpolyn createpolyn(polyn head,int m);/创建链表(多项式)void destroypolyn(polyn p);/销毁void printpolyn(polyn p);/输出polyn addpolyn(polyn pa,polyn pb);/a+bpolyn subtractpolyn(polyn pa,polyn pb);/a-bpolyn multiplypolyn(polyn pa,polyn pb);/a*b void main()/主函数系统共分几个模块,每个模块的算法描述及流程图(核心模块)1系统模块图(模块划分)图1 系统模
5、块划分图2 模块流程图及算法描述 分模块流程图(1)多项式的创建 (2)多项式的销毁开始从键盘输入项数mmnextq不为空ny结束输出“-x(q的指数)”输出“-x”输出“-1”输出x(q的指数)输出“x”输出“x”输出x(q的指数)yn(4)多项式的相加开始定义存储和链表hc动态分配空间qa=pa-nextqb=pb-nextqa!=qb?yqaqb?yqa的各个值赋给qcqa指向qa的nextqb的各个值赋给qcqb指向qb的nextnqa的系数加qb的系数赋给qc的系数qa的指数赋给qc的指数qa指向qa的nextqb指向qb的nextqc插入到hc中qc的系数不为0y释放qc空间结束(
6、5)多项式的相减 (6)多项式的相乘开始定义存储和链表h动态分配空间p=p-coef*(-1)两多项式相加输出p不为0?p=p-nextyn结束开始定义存储和链表hf动态分配空间qa=pa-nextqb=pb-nextqb存在?qa存在?y定义存储和链表pf动态分配空间将qa和qb的系数相乘赋给pf的系数将qa和qb的指数相加赋给pf的指数将pf插入到hf中qb=pb-nextynqa=qa-next返回hf结束算法描述(1)多项式的创建polyn createpolyn(polyn head,int m) /建立一个头指针为head、项数为m的一元多项式 /在主程序初始时,先输入的多项式中的
7、项数m、n 在这里为m。主程序中的pa、pb在此为headint i;/用来计数 polyn p;/定义一个p链表 p=head=(polyn)malloc(sizeof(struct polynomial);/动态分配空间,建立头结点 head-next=null; for(i=0;icoef,&p-expn); insert(p,head); /调用insert函数插入结点p return head;(2)多项式的销毁利用循环逐渐销毁多项式void destroypolyn(polyn p) /销毁多项式p polyn q1,q2; q1=p-next; q2=q1-next; while
8、(q1-next)/利用循环逐渐销毁多项式pfree(q1); q1=q2;/指针后移 q2=q2-next;free(q1);(3)多项式的输出void printpolyn(polyn p) /输出多项式polyn q=p-next; int flag=1;/项数计数器 if(!q) /若多项式为空,输出0 putchar(0); printf(n); return; while(q) /多项式存在 if(q-coef0&flag!=1) putchar(+); /系数大于0且不是第一项if(q-coef!=1&q-coef!=-1) /系数非1或-1的普通情况 printf(%g,q-c
9、oef); /%g表示使用%e或%f,哪个输出宽度稍短就使用哪一个 if(q-expn=1) putchar(x); /若指数为1 else if(q-expn) printf(x%d,q-expn); /指数不为1 else if(q-coef=1) /系数为1的情况 if(!q-expn) putchar(1); /指数为0,则为1 else if(q-expn=1) putchar(x); /指数为1则为xelse printf(x%d,q-expn); if(q-coef=-1)/系数为-1的情况if(!q-expn) printf(-1); /指数为0,则为-1else if(q-e
10、xpn=1) printf(-x); /指数为1,则为-xelse printf(-x%d,q-expn);q=q-next; flag+; /项数加1 printf(n);(4)多项式的相加利用对a、b两个多项式每一项分模块讨论进行的,如a指数大或者b空,则将a项该节点插入新链c中,若b指数大或者a空,则将b项插入到c中,如若a、b两项指数相等,则合并后再插入到c链中。polyn addpolyn(polyn pa,polyn pb) /求解并建立多项式a+b,返回其头指针 polyn qa=pa-next; polyn qb=pb-next; polyn headc,hc,qc; hc=(
11、polyn)malloc(sizeof(struct polynomial);/建立头结点 hc-next=null; headc=hc; while(qa|qb) qc=(polyn)malloc(sizeof(struct polynomial); switch(compare(qa,qb)case 1: qc-coef=qa-coef; qc-expn=qa-expn; / a的指数大或b为空,把qa赋值给qc qa=qa-next; /qa指向下一个 break;case 0: qc-coef=qa-coef+qb-coef; qc-expn=qa-expn; /qc等于qa与qb的和
12、 qa=qa-next; qb=qb-next; /qa,qb都分别指向下一个 break;case -1: qc-coef=qb-coef; /b的指数大或a为空,把qb赋值给qc qc-expn=qb-expn; qb=qb-next; /qb指向下一个 break; if(qc-coef!=0) qc-next=hc-next;/qc插入到hc中去,并重新生成新的hc,到最后实现a与b的和 hc-next=qc; hc=qc;else free(qc);/当相加系数为0时,释放该结点 return headc; /返回头指针,实现多项式a与b的相加(5)多项式的相减利用a-b=a+(-b
13、)来进行的,即只将b系数取反即可。polyn subtractpolyn(polyn pa,polyn pb)/求解并建立多项式a-b,返回其头指针,将pb的系数取反后调用相加的函数,实现相减功能 polyn h=pb; polyn p=pb-next; polyn pd;while(p) /将pb的系数取反 p-coef*=-1; p=p-next; /p向后移动 pd=addpolyn(pa,h); for(p=h-next;p;p=p-next) /恢复pb的系数 p-coef*=-1; return pd; /返回pd的值,实现a与b两个多项式相减(6)多项式的相乘将a中的每一项乘b中
14、的每一项,即系数相乘,指数相加,将它放在新节点中并插入新链h,最后返回链h。polyn multiplypolyn(polyn pa,polyn pb) /求解并建立多项式a*b,返回其头指针 polyn hf,pf; polyn qa=pa-next; polyn qb=pb-next; hf=(polyn)malloc(sizeof(struct polynomial);/建立头结点 hf-next=null; for(;qa;qa=qa-next) for(qb=pb-next;qb;qb=qb-next) pf=(polyn)malloc(sizeof(struct polynomia
15、l); pf-coef=qa-coef*qb-coef; pf-expn=qa-expn+qb-expn; insert(pf,hf);/调用insert函数以合并指数相同的项 return hf;3 测试结果与分析系统选择界面如图1图1输入数据为:2(enter)2(pase)3(enter)8(pase)2(enter)3(enter)5(pase)1(enter)3(pase)6(enter)7(pase)2(enter)图2输出菜单:如图2图3分别输入a,b,c,d,e五个选项显示结果:如图4图4输入f,结束,显示结果:如图五图54 课程设计总结一 程序总结计算一元多项式加法,其结果取
16、决于多项式的各项系数与指数,因此程序核心是处理两个多项式的系数与指数。定义结构体将多项式的各项系数与指数存放,定义结构体类型链表为程序的循环控制提供了可能,利用对链表的运算来确定结果多项式的各项系数与次数,同理算出相应的幂数。链表是在计算机内存中使用一组连续的存储单元保存数据类型和名字相同的变量。就链表这种数据类型而言,在排列上采用的方法也是按序排放,先存放第一行,接着存放第二行,直到所有数据元素被存放。多项式采用的是链表形式,以牺牲一定的空间提高程序的运行速度和可行性。采用链式结构存储多项式,用链表结构体的一个域标记多项式的次数,另一个域标记多项式的系数,程序中采用的是m表示最高次系数,进行
17、加法运算时,标记系数域相加即为相加的对应系数,标记指数域相同则表示为同类项。链表的特性是在中间任意位置添加删除元素的都非常的快,不需要移动其它的元素。链表顾名思义,要把各个元素链接起来才算撒。通常链表每一个元素都要保存一个指向下一个元素的指针(单链表)。二 错误分析错误产生的原因有很多:1. 函数定义冲突;2. 函数调用错误; 3. 符号字母等输入错误;4. 链表的定义错误;5. 变量名重复发生冲突;6. 指针指向发生错误;7. 未释放空空间;错误显示:如图6 图6三收获与体会本次课程设计,我查找过资料,请教过同学,以及自己的努力,不仅培养了独立思考、动手操作的能力,在各种其它能力上也都有了提
18、高。更重要的是,在程序设计中,我学会了很多学习的方法,而这是日后最实用的,真的是受益匪浅。本学期的程序设计课程,我锻炼了能力,学到很多东西,比如思考问题的角度也会从多方面着手;对自己的专业也有自己的想法在和同学的交流过程中,互动学习,将知识融会贯通。通过这次课程设计,我对很多的函数有了新的认识,也学会了运用多种函数,我也明白了写软件的基本过程和基本方法。在程序的设计过程中遇到了很多的困难,在程序一次一次的调试失败下曾经想过要放弃,我最后还是让自己坚持下来,毫不畏惧困难,在同学的帮助与讲解下我总算是顺利的完成了程序的课程设计。另外也需要提出的是在这次程序设计的过程中,非常感谢老师对我们的耐心指导
19、。老师在教学过程中表现出来的对学术专研一丝不苟的精神让我非常有收获。在这几天的编写过程中我对语言有了更进一步的认识和了解,也感受到了编程给我带来的快乐与充实,明白了想成为一个合格的甚至是优秀的程序员,我还需要更多更难的锻炼。所以我还要不断地学习不断地学习,不断地成长。参考文献:1严蔚敏,吴伟民数据结构(c语言版)北京:清华大学出版社,19972朱战立 数据结构西安:西安电子科技大学出版社,20043严蔚敏,吴伟民 数据结构题集(c语言版)北京:清华大学出版社,2000附录a: 源程序清单#include#include#include/定义多项式数据结构typedef struct polyn
20、omial float coef; /系数 int expn; /指数 struct polynomial *next; /下一个指针*polyn,polynomial; /polyn结构体变量名void insert(polyn p,polyn h);/将结点p插入链表hpolyn createpolyn(polyn head,int m);/创建链表(多项式)void destroypolyn(polyn p);/销毁void printpolyn(polyn p);/输出int compare(polyn a,polyn b);/比较a,b的指数大小,为下面a+b做铺垫polyn add
21、polyn(polyn pa,polyn pb);/a+bpolyn subtractpolyn(polyn pa,polyn pb);/a-bpolyn multiplypolyn(polyn pa,polyn pb);/a*b /*主函数*/void main() int m,n,a,x;char flag; polyn pa=0,pb=0,pc;/system(color f5);/字体颜色system(color 5f);/背景颜色printf(n);printf(*w e l c o m e*nn);printf(*【欢迎使用简便式一元多项式计算程序】*nn);printf(*nn)
22、;printf(*【使用说明:您可建立a,b两个多项式,并进行相加、相减、相乘三种运算】*nn);printf(*nn);printf(*【请按以下提示请输入您所需的数据】*nn);printf(请输入a的项数:); scanf(%d,&m); pa=createpolyn(pa,m);/建立多项式a printf(请输入b的项数:); scanf(%d,&n); pb=createpolyn(pb,n);/建立多项式bsystem(cls);printf(n);printf(*n);printf(* a.【输出多项式a】*n);printf(* b.【输出多项式b】*n);printf(*
23、c.【 输出a+b 】*n);printf(* d.【 输出a-b 】*n);printf(* e.【 输出a*b 】*n);printf(* f.【 退出程序 】*n); printf(*n);while(1) printf(n请选择操作:); scanf( %c,&flag);/空格符号一定要注意switch(flag)casea:casea:printf(n 多项式a=);printpolyn(pa);break;caseb:caseb:printf(n 多项式b=);printpolyn(pb);break;casec:casec:pc=addpolyn(pa,pb); printf(
24、n a+b=);printpolyn(pc);break;cased:cased:pc=subtractpolyn(pa,pb);printf(n a-b=);printpolyn(pc);break;casee:casee:pc=multiplypolyn(pa,pb);printf(n a*b=);printpolyn(pc);break;casef:casef:system(cls);printf(n);printf(n);printf(t*nn);printf(t* 感谢使用此程序 *nn);printf(t* o(_)o *nn);printf(t* 再 见 *nn);printf(
25、t* made by ydh *nn);printf(t*nn);destroypolyn(pa);destroypolyn(pb);return;default:printf(n 您的选择错误,请重新选择!n);/*合并两个多项式*/void insert(polyn p,polyn h) /将两个多项式合并的算法,即将p插入h来实现 if(p-coef=0) free(p);/系数为0的话释放结点 else polyn q1,q2; q1=h; q2=h-next; while(q2&p-expnexpn)/查找插入位置,直到p结点指数大于等于h结点 q1=q2; q2=q2-next;
26、if(q2&p-expn=q2-expn)/将指数相同相合并,指数相等时,系数相加 q2-coef+=p-coef; free(p); if(!q2-coef)/系数为0的话释放结点 q1-next=q2-next;/将q2释放掉 free(q2); else/指数为新时将结点插入 p-next=q2; /将p结点插入到h中去 q1-next=p;/*建立一元多项式*/polyn createpolyn(polyn head,int m) /建立一个头指针为head、项数为m的一元多项式 /在主程序初始时,先输入的多项式中的项数m、n 在这里为m。主程序中的pa、pb在此为headint i;
27、/用来计数 polyn p;/定义一个p链表 p=head=(polyn)malloc(sizeof(struct polynomial);/动态分配空间,建立头结点 head-next=null; for(i=0;icoef,&p-expn); insert(p,head); /调用insert函数插入结点p return head;/*销毁多项式*/void destroypolyn(polyn p) /销毁多项式p polyn q1,q2; q1=p-next; q2=q1-next; while(q1-next)/利用循环逐渐销毁多项式pfree(q1); q1=q2;/指针后移 q2
28、=q2-next;free(q1);/*输出多项式*/void printpolyn(polyn p) /输出多项式polyn q=p-next; int flag=1;/项数计数器 if(!q) /若多项式为空,输出0 putchar(0); printf(n); return; while(q) /多项式存在 if(q-coef0&flag!=1) putchar(+); /系数大于0且不是第一项if(q-coef!=1&q-coef!=-1) /系数非1或-1的普通情况 printf(%g,q-coef); /%g表示使用%e或%f,哪个输出宽度稍短就使用哪一个 if(q-expn=1)
29、 putchar(x); /若指数为1 else if(q-expn) printf(x%d,q-expn); /指数不为1 else if(q-coef=1) /系数为1的情况 if(!q-expn) putchar(1); /指数为0,则为1 else if(q-expn=1) putchar(x); /指数为1则为xelse printf(x%d,q-expn); if(q-coef=-1)/系数为-1的情况if(!q-expn) printf(-1); /指数为0,则为-1else if(q-expn=1) printf(-x); /指数为1,则为-xelse printf(-x%d,
30、q-expn);q=q-next; flag+; /项数加1 printf(n);/*分模块讨论*/int compare(polyn a,polyn b) if(a&b) if(a-expnb-expn) return 1; /b为空或a的指数大 else if(a-expnexpn) return -1; /a为空或者b的指数大else return 0; else if(!a&b) return -1;/a多项式已空,但b多项式非空else return 1;/b多项式已空,但a多项式非空 /*建立多项式a+b*/polyn addpolyn(polyn pa,polyn pb) /求解并建立多项式a+b,返回其头指针 polyn qa=pa-next; polyn qb=pb-next; polyn headc,hc,qc; hc=(polyn)malloc(sizeof(struct polynomial);/建立头结点 hc-next=null; headc=hc; while(qa|qb) qc=(polyn)malloc(sizeof(struct polynomial); switch(compare(qa,qb)case 1: qc-coef=qa-coef; qc-expn=qa-expn; / a的指数大或
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 医疗物资采购风险管理与控制
- 代买货物合同范例
- 买卖门市定金合同范例
- 2025年小学班主任工作总结经验教训总结模版
- 买卖大型设备合同范例
- 公司配件采购合同范例
- 广电工作者个人年度工作总结模版
- 人口健康信息分析与教育引导
- erp系统维护合同范例
- 专职教室聘用合同范例
- 酒店业大数据分析与精准营销应用
- 红色研学策划方案(2篇)
- 个人形象品牌代言协议
- 中职技能大赛“导游服务”赛项旅游政策与法规及旅游热点问题题库(含答案)
- HY/T 0379-2023赤潮灾害风险评估与区划导则
- 2024年安庆市金融控股集团有限公司招聘笔试参考题库附带答案详解
- 代收代付协议书模板(2篇)
- 汽车配件中英文名称对照
- 大型峰会会务服务会务就餐保障方案
- 政务新闻摄影技巧培训课件
- 上海滩钢琴简谱数字双手乐谱
评论
0/150
提交评论