数据结构实系数一元多项式运算实验报告.doc

上传人:jian****018 文档编号:9058876 上传时间:2020-04-02 格式:DOC 页数:10 大小:37.50KB
返回 下载 相关 举报
数据结构实系数一元多项式运算实验报告.doc_第1页
第1页 / 共10页
数据结构实系数一元多项式运算实验报告.doc_第2页
第2页 / 共10页
数据结构实系数一元多项式运算实验报告.doc_第3页
第3页 / 共10页
点击查看更多>>
资源描述
实系数一元多项式问题实验报告2010级计算机科学与技术(非师范)100704033鲁静2011年10月14日星期五1、需求分析实现实系数一元多项式的创建,打印以及两个一元多项式的加、减、乘运算。(1)程序所能达到的功能: a实现一元多项式的输入; b实现一元多项式的输出; c计算两个一元多项式的和并输出结果;d计算两个一元多项式的差并输出结果;e计算两个一元多项式的积并输出结果;(2)输入的形式和输入值的范围:输入要求:分行输入,每行输入一项,先输入多项式的指数,再输入多项式的系数,以0 0为结束标志,结束一个多项式的输入。输入形式:2 3-1 23 01 20 0-2 1-3 3-1 -10 0输入值的范围:系数为int型,指数为float型。(3)输出的形式:要求:第一行输出多项式1; 第二行输出多项式2;第三行输出多项式1与多项式2相加的结果多项式;第四行输出多项式1与多项式2相减的结果多项式;第五行输出多项式1与多项式2相乘的结果多项式注: 多项式的每一项形如:2.0x3,注意指数应保留一位小数;多项式按照升幂次序排列; 系数为1的非零次项应略去系数,系数为0的项不能出现在结果中; 指数为0的项应只输出系数; 多项式的第一项系数符号为正时,不要输出“+”,其他项要输出“+”,“-”符号。输出形式:3.0+2.0x3-x-1-2.0x-3.0x3-x-1+3.0-2.0x-x3x-1+3.0+2.0x+5.0x3-3.0x-1-6.0x-2.0x2-9.0x3-4.0x4-6.0x62、概要设计抽象数据类型一元多项式的定义如下:ADT Polynomial 数据对象:D=ai| ai TermSet,i=1,2,m,m0TermSet 中的每个元素包含一个表示系数的实数和表示指数的整数 数据关系:R1=| ai-1 , ai D,且ai-1 中的指数值ai 中的指数值,i=2,n 基本操作:sort(Polyn & h); /对多项式进行排序print(Polyn h); /输出多项式delZeroCoef(Polyn & h); /判断系数为零的情况merge(Polyn & h); /合并指数相同的项createList(); /创建多项式addPoly(Polyn h1,Polyn h2); /多项式相加subPoly(Polyn h1,Polyn h2); /多项式相减multPoly(Polyn h1,Polyn h2); /多项式相乘 ADT Polynomial多项式的抽象数据类型的定义: typedef struct Polynomial /结点类型float coef; /系数int exp; /指数struct Polynomial * next;PolyNode,*Polyn;判断h1,h2系数是否为0输入两个多项式h1,h2开始主程序的流程图:调用multPoly(h1,h2),合并并输出调用subPoly(h1,h2),合并并输出调用addPoly(h1,h2),合并并输出结束调用print()函数,输出,合并过并排好序的h1,h23、详细设计伪码算法: 主函数: int main() Polyn h1=createList();/创建多项式1 Polyn h2=createList();/创建多项式2 print(h1); /输出多项式1 print(h2); /输出多项式2 addPoly(h1,h2); /实现多项式1和2的相加,并输出 subPoly(h1,h2); /实现多项式1和2的相减,并输出 multPoly(h1,h2); /实现多项式1和2的相乘,并输出 return 0; 分支函数: void sort(Polyn & h); /排序 void print(Polyn h); /输出多项式 void delZeroCoef(Polyn & h);/判断处理系数为0的情况 void merge(Polyn & h); /合并多项式 Polyn createList(); /创建多项式 void addPoly(Polyn h1,Polyn h2);/两个多项式相加并输出 void subPoly(Polyn h1,Polyn h2);/两个多项式相减并输出 void multPoly(Polyn h1,Polyn h2);/两个多项式相乘并输出函数的调用关系:mainmultPolycreateListsubPolyprintaddPolyprintmergeprintmergeprintmergemergesortdelZeroCoef4、 调试分析a 调试过程中遇到的问题是如何解决的以及对设计与实现的回顾讨论和分析: 在输入诸如“0,3”,“2,0”时,程序无法正常运行或总是出错. 解决:对指数或系数为0的情况应单独讨论。为此,建立了delZeroCoef函数来解决问题。 b算法的时空分析(包括基本操作和其他算法的时间复杂度和空间复杂度的分析)和改进设想: 时间复杂度和空间复杂度: 设两个多项式分别用m,n来表示,T()表示时间复杂度,O()表示空间复杂度,那么: sort(Polyn & h):T(m*m),T(n*n);O(m),O(n)。 print(Polyn h):T(m),T(n);O(1),O(1)。 delZeroCoef(Polyn & h):T(m),T(n);O(1),O(1)。 merge(Polyn & h):T(m*m),T(n*n);O(1),O(1)。 createList():T(m),T(n);O(1),O(1)。 addPoly(Polyn h1,Polyn h2):T(m),T(n);O(1),O(1)。 subPoly(Polyn h1,Polyn h2):T(m),T(n);O(1),O(1)。 multPoly(Polyn h1,Polyn h2):T(m),T(n);O(1),O(1)。 改进设想: 可以在原来的基础上改进程序,或者设计一些新的算法,尽量减小时间复杂度和空间复杂度。c经验和体会: 1.这次用链表来解决问题让我的收获很大,对链表的构建更加熟练,对链表的向前推进把握的更加准确,在调试代码,检验的时候,曾遇到很大的阻碍,但解决问题后,自己也收获了很多。 2.通过本次实验,我发现自己分析问题不是很全面,容易忽略一些细节,以后分析问题时要仔细考虑认真分析,避免细节上的错误。 3.在设计该算法时,由于过于依赖书本上的例子,导致很多不必要的麻烦,例如在建立链表时头指针的设立导致了之后运用到相关的指针时没能很好的移动指针出现了数据重复输出或是输出系统缺省值,不能实现算法。5、 测试数据与测试结果第一组数据:输入:2 43 21 52 30 05 32 36 53 67 44 80 0输出:3.0x2+2.0x3+2.0x4+x57.0x3+7.0x4+6.0x5+3.0x6+4.0x83.0x2+9.0x3+9.0x4+7.0x5+3.0x6+4.0x83.0x2-5.0x3-5.0x4-5.0x5-3.0x6-4.0x821.0x5+35.0x6+46.0x7+42.0x8+25.0x9+24.0x10+11.0x11+8.0x12+4.0x13Press any key to continue第二组数据:输入:4 60 43 35 24 10 02 03 53 64 70 0输出:4.0x+5.0x2+3.0x3+4.0x62.0+3.0x5+3.0x6+4.0x72.0+4.0x+5.0x2+3.0x3+3.0x5+7.0x6+4.0x7-2.0+4.0x+5.0x2+3.0x3-3.0x5+x6-4.0x78.0x+10.0x2+6.0x3+20.0x6+27.0x7+40.0x8+29.0x9+12.0x10+12.0x11+12.0x12+16.0x13Press any key to continue第三组数据:输入:-2 12 -33 09 57 -40 0-6 50 85 -6-3 49 00 0输出:7.0x-4+2.0x-3+3.0-2.0x+9.0x55.0x-6+9.0-3.0x4-6.0x55.0x-6+7.0x-4+2.0x-3+12.0-2.0x-3.0x4+3.0x5-5.0x-6+7.0x-4+2.0x-3-6.0-2.0x+3.0x4+15.0x535.0x-10+10.0x-9+15.0x-6-10.0x-5+63.0x-4+18.0x-3+45.0x-1+6.0-66.0x-12.0x2-9.0x4+69.0x5+12.0x6-27.0x9-54.0x10Press any key to continue第四组数据:输入:3 -9-7 8-2 -47 80 3-1 00 02 -3-4 31 00 -50 0输出:3.0x-9-2.0x-4-1.02.0x-3+1.0-4.0x33.0x-9-2.0x-4+2.0x-3-4.0x33.0x-9-2.0x-4-2.0x-3-2.0+4.0x36.0x-12+3.0x-9-4.0x-7-12.0x-6-2.0x-4-2.0x-3+8.0x-1-1.0+4.0x3Press any key to continue第五组数据:输入:1 -1-1 10 01 -1-1 -10 0输出:x-1-x0x-1-xx-1-x0Press any key to continue
展开阅读全文
相关资源
相关搜索

当前位置:首页 > 管理文书 > 工作总结


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!