数据结构课程设计-n元多项式乘法.docx
《数据结构课程设计-n元多项式乘法.docx》由会员分享,可在线阅读,更多相关《数据结构课程设计-n元多项式乘法.docx(19页珍藏版)》请在第一文库网上搜索。
1、数据结构课程设计报告N元多项式乘法目录1课程设计内容32课程设计分析33 思路原理54 程序简图55算法(数据结构)描述66程序清单74.1 单链表表示74.2 数组表示157运行与调试分析168 收获与体会179 参考文献181课程设计内容功能:完成两个n元多项式作乘法,给出明确的等式形式。分步实施:1)初步完成总体设计,搭好框架,确定人机对话的界面,确定函数个数;2)完成最低要求:建立一个文件,实现两个一元二次多项式作乘法。3)进一步要求:实现三元二次多项式的乘法。有兴趣的同学可以自己扩充系统功能。2课程设计分析本程序用的存储方式是单链表,单链表在C语言中是一种非常常见的结构,而在C+中的
2、实现却又有不同,在一些地方更简单,更严密。同时,由于C+的一些特点,使它具有C语言所不具有的“安全化”,所以本程序用C+。有了链表特定的数据类型MUIPOIy,接下来就需要建立这个链表。这里定义了一个构造函数CreatePo1y来构造链表。首先定义一个CreatePo1y型的指针变量head作为头结点,存储多项式的信息(项数),为head分配存储空间建立一个头结点并为其数据域赋值,分配存储空间用c+语言中的maoc来实现;这时输入多项式的项数num,把它赋值给head的coef域,exp域赋值为1此时再定义一个CreatePo1y型的指针变量r指向head头结点。还要用类似的算法建立多项式的其
3、它结点,剩余节点的插入用一个whi1e循环来实现,whi1e循环中的控制变量i从大于0的数n开始递增,直到到达num,此时WhiIe循环结束。Whi1e循环的循环体由两部分组成,第一部分是为指针变量s分配存储空间和为其数据域赋值,分配存储空间同样用c+语言中的ma1hc来实现;第二部分是节点的指针域转换过程,将r的指针域指向新生成的结点s,相当于将生成结点依次用指针连接,然后将最后一个结点的指针域设置为NU11,具体代码如下:Mu1Po1y*CreatePo1yOMu1Po1y*head,*r,*s;intm,n,num,i=1;head=(Mu1Po1yma11oc(sizeof(Mu1Po
4、1y);COUt请输入多项式的项数,num;head-coef=num;head-exp=1;r=head;whi1e(i=num)/n不为0时建立多项式链表s=(Mu1Po1yma11oc(sizeof(Mu1Po1y);COUt输入第0i组系数和指数znm;s-exp=m;s-coef=n;r-next=s;r=s;1+;)r-next=nu11;return(head);)在处理多项式相乘的问题时,定义一个Po1yMUIti函数实现,需要再建立一个Mu1Po1y型的链表存储相乘之后的链表,定义结果链表的系数等于链表P1的系数乘以链表P2的系数:(p-coef)=(p1-COef)*(p2
5、-coef)结果链表的指数等于链表P1的指数乘以链表P2的指数:(p-exp)=(p1-exp)+(p2-exp)。在整理之后可能出现零结点,那么就需要进行判断和删除操作同时释放零结点,这些操作是通过一个WhiIe循环来完成。具体代码如下:whi1e(p!=q)s=q;q=q-next;s-next=q-next;free(q);还需要定义一个输出函数,在主函数中调用输出两个多项式相乘后的结果。程序的最终都是由主函数来实现。在主函数中通过对一些自定义函数的调用实现具体的操作。在此主函数调用了一个构建链表的函数CreatePo1y、一个删除空结点的函数DeIete和输出函数Print。在主函数的
6、开始需要定义三个MU1PO1y型指针变量,分别用来存储调用CreatePo1y函数和Po1yMu1ti函数生成的链表和结果链表。在构建链表之前要给节点分配存储空间,s=(Mu1Po1y*)ma11oc(Sizeof(Mu1Po1y);这条语句便可完成此操作。此条语句运用了c+语言库函数中的maoc函数,这个函数的作用是在内存的动态存储区中分配一个长度为SiZeof(MU1POIy)的内存空间。调用构建链表函数CreatePo1y后链表P1便构建完成。接下来需要执行m=Po1yMu1ti(p,q);语句,这条语句的目的是把多项式P1和P2相乘的结果多项式存储在链表m当中,然后执行Print(m)
7、;语句显示输出。主函数的程序框架如下:intmain()Mu1Po1y*p,*q,*m;P=CreatePo1yO;Q=CreatePo1yO;m=PoIyMu1ti(p,q);Merge_Same(m);Print(m);system(zzpausezz);)程序的调试是程序顺利完成中非常关键的一步。通过程序的调试分析可以解决程序的运行错误也可以对程序的性能进行分析。这个多项式运算问题研究的程序最重要的就是看输出的链表是否正确,是否带有空结点,合并是否完全。决定程序成功与否的第一步是定义的P。IyMU1ti函数操作是否正确。如果这一步中出现错误,那么接下来的操作可以说是错上加错。在调试的时候
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 课程设计 多项式 乘法