数据结构实验报告一元多项式的加法运算.docx
《数据结构实验报告一元多项式的加法运算.docx》由会员分享,可在线阅读,更多相关《数据结构实验报告一元多项式的加法运算.docx(8页珍藏版)》请在三一办公上搜索。
1、数据结构实验报告一元多项式的加法运算问题描述: 设Pn(x)和Qm(x)分别两个一元多项式。试编写程序实现一元多项式的加法运算。 一、需求分析: 1、本程序需要基于线性表的基本操作来实现一元多项式的加法,也可以用数组实现。 2、两个多项式都有键盘输入相应的系数和指数。 3、/第一个多项式为9x15+ 7x8+5x3+3x 输入 4 /表示第一个多项式的项数 9, 15 /表示9x15 7, 8 5, 3 3, 1 输出 9x15+ 7x8+5x3+3x1 /第二个多项式为 -7x8+6x3+2 输入 3 /表示第二个多项式的项数 6, 3 /表示9x15 -7, 8 2, 0 输出 -7x8+
2、 6x3+2x0 求和结果 9x15+11x3+3x1+ 2x0 二、概要设计 : 抽象数据类型 为实现上述程序的功能,应以整数存储用户的输入,以及计算的结果。 实现多项式的运算,利用数组的方式需开辟一个二维数组,利用链表的方式须创造两个链表。 算法的基本思想 数组实现: 定义一个结构体数组,p存储系数,q存储指数。分别输出两次输入的多项式。将两次输入的多项式的指数按从大到小的顺序进行排列,同时相应的系数要进行交换。输出时如果进行判断。如果当前该项与下一项的的系数相同,将两项系数相加后输出,并跳过下一项。 如果不相等,直接输出。 输出时需注意的问题: 当系数为0时,该项不输出 当系数为负数时,
3、不要再在前面输出+。 程序的流程 程序由三个模块组成: 输入模块:完成两个多项式的输入。 处理模块:将多项式按其指数大小进行排列。 输出模块:输出合并后的多项式。 三、详细设计 算法的具体步骤: 数组方法 : struct code int p,q; a1000,b1000;/结构体数组,可以用二维数组代/替 for(i=0;in;i+) for(j=i+1;jai.q) temp=aj.q;/指数排序 aj.q=ai.q; ai.q=temp; temp=aj.p;/系数跟着变化 aj.p=ai.p; ai.p=temp; /对输入的指数进行排序,相应的系数跟着变化 couta0.px0)
4、else if(ai.p0) coutai.pxai.q; cout+ai.pxai.q;/完成运算符和其他项的输/出,然后类似于上面,对第二个多项式进行相应的操作。 for(i=0;im;i+) an+i.q=bi.q; an+i.p=bi.p; /将两个多项式的指数,系数存储到一个数组 for(i=0;im+n;i+) for(j=i+1;jai.q) temp=aj.q; aj.q=ai.q; ai.q=temp; temp=aj.p; aj.p=ai.p; ai.p=temp; /按指数由大到小进行排列 if(a0.q!=a1.q) couta0.pxa0.q; j=1; else c
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 实验 报告 一元 多项式 加法 运算

链接地址:https://www.31ppt.com/p-3111251.html