ImageVerifierCode 换一换
格式:DOC , 页数:17 ,大小:123.50KB ,
资源ID:6359159      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-6359159.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构课程设计——一元稀疏多项式.doc)为本站会员(hskm5268)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

数据结构课程设计——一元稀疏多项式.doc

1、课程设计说明书设计题目: 数据结构课程设计 专 业: 班级: 设 计 人: 课 程 设 计 任 务 书一、课程设计题目:设计一个一元稀疏多项式计算器 二、设计原始资料:数据结构 C 语言版教材及习题集 三、设计应解决下列各主要问题: 1、输入并建立一元稀疏多项式 2、输出多项式,输出形式为整数序列 n,c1,e1,c2,e2,cn,en,其中 n 是多项式的项数,ci 和 ei 分别是第 I 项的系数和指数,序列指指数降序排列; 3、多项式 a 和 b 相加,建立多项式 a+b; 4、多项式 a 和 b 相减,建立多项式 a-b。 四、设计说明书应附有下列图纸: 五、命题发出日期: 设计应完成

2、日期: 设计指导教师(签章): 系主任(签章): 指导教师对课程的评语指导教师(签章): 年 月 日学生课程设计一、 需求分析1. 演示程序以用户和计算机的对话方式执行,即在计算机终端上显示“提示信息”之后,由用户在键盘上输入演示程序中规定的运算命令;相应的输入数据和运算结果显示在其后。2. 程序执行的命令包括:1) 创建一元多项式 1;2) 创建一元多项式 2;3) 输出一元多项式4) 计算多项式 1 和多项式 2 的和;5) 计算多项式 1 和多项式 2 的差注意:输出形式为整数序列 n,c1,e1,c2,e2,cn,en,其中n 是多项式的项数,ci 和 ei 分别是第 I 项的系数和指

3、数,序列指指数降序排列3.测试数据1) )721.3()157()1.352( 9988 xxxxx;2) ;254342 3) 0)()(33xx4) )22 x二、 概要设计为实现上述程序功能,应以带头结点的单链表存储多项式1. 多项式的抽象数据类型为:ADT Polynmial数据对象:D=ai|aiTermSet,i=1,2,3,m,TermSet 中的每一个元素包含一个表示系数的实数和表示指数的整数学生课程设计数据关系:R1=ai-1,aiD,且 ai-1中的指数next=NULL;for(i=0; icoef,Insert(p,head); /调用 Insert 函数插入结点ret

4、urn head;void DestroyPolyn(Polyn p)/销毁多项式 pq1=p-next;q2=q1-next;while(q1-next)free(q1);q1=q2;q2=q2-next;void Insert(Polyn p,Polyn h)if(p-coef=0) free(p);/系数为 0 的话释放结点elseq1=h;q2=h-next;学生课程设计while(q2q2=q2-next;if(q2free(p);if(!q2-coef)/系数为 0 的话释放结点q1-next=q2-next;free(q2);else/指数为新时将结点插入p-next=q2;q1

5、-next=p;学生课程设计void PrintPolyn(Polyn P)Polyn q=P-next;int flag=0;/项数计数器while(q)flag+;q=q-next;q=P-next;if(!q)/若多项式为空,输出 0putchar(0);printf(“n“);return;printf(“%d “,flag);while(q)if(q-coef!=1学生课程设计elseif(q-coef=1)printf(“%g %d “,q-coef,q-expn);if(q-coef=-1)printf(“%g %d “,q-coef,q-expn);q=q-next;print

6、f(“n“);int compare(Polyn a,Polyn b)if(aelse if(!a|a-expnexpn) return -1;else return 0;else if(!a/a 多项式已空,但 b 多项式非空学生课程设计else return 1;/b 多项式已空,但 a 多项式非空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);

7、/建立头结点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;qa=qa-next;break;学生课程设计case 0:qc-coef=qa-coef+qb-coef;qc-expn=qa-expn;qa=qa-next;qb=qb-next;break;case -1:qc-coef=qb-coef;qc-expn=qb-expn;qb=qb-next;break;if

8、(qc-coef!=0)qc-next=hc-next;hc-next=qc;hc=qc;else free(qc);/当相加系数为 0 时,释放该结点return headc;学生课程设计Polyn SubtractPolyn(Polyn pa,Polyn pb) /求解并建立多项式 a-b,返回其头指针Polyn h=pb;Polyn p=pb-next;Polyn pd;while(p)/将 pb 的系数取反p-coef*=-1;p=p-next;pd=AddPolyn(pa,h);for(p=h-next; p; p=p-next) /恢复 pb 的系数p-coef*=-1;retur

9、n pd;3.主函数及其他函数的伪代码算法Int main()CreatPolyn(a);CreatPolyn(b);交互界面菜单;学生课程设计Switch(choose)Case a: printf(a);Case b: printf(b);Case c: printf(a+b);Case d: printf(a-b);Case e: exit;四、 测试结果1.人机交互界面2.测试结果显示学生课程设计 )721.3()157()1.352(9988 xxxxx )1()()1(25435432 xxxx学生课程设计0)()(33xx)(0)(2332 xx学生课程设计五、 总结反思经过这段

10、为期不久的课程设计,使我对于数据结构有了更深层次的理解,对于链表这种数据结构的认识也更加深刻了。 在这个过程中。我曾因为实践经验缺乏,错误过多失落过;也曾经仿真成功而热情高涨。我也感觉用心细心地做好一件事情的重要性,在这次课程设计中,体会到了做设计的严谨,更加加深了我对课程设计的兴趣。在此次课程设计过程中,遇到不懂的问题我会及时向老师,同学请教或者是在网上查询相关的资料,以更好地完成该项课题设计。在实践结束后,深深地体会到实践对于工科专业的重要性。在学习数据结构的过程中总是觉得有些东西模棱两可,感觉到不能深一步的理解,也因为代码的冗长而缺乏耐心去完成每一个。通过这次课程设计,原本关于链表的模棱两可的东西逐渐变得清晰起来,以后一定加强动手实践的能力,多动手,多思考!

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报