《数据结构》课程设计报告-多项式计算器

《数据结构》课程设计报告-多项式计算器

ID:35627430

大小:369.50 KB

页数:11页

时间:2019-04-03

《数据结构》课程设计报告-多项式计算器_第1页
《数据结构》课程设计报告-多项式计算器_第2页
《数据结构》课程设计报告-多项式计算器_第3页
《数据结构》课程设计报告-多项式计算器_第4页
《数据结构》课程设计报告-多项式计算器_第5页
资源描述:

《《数据结构》课程设计报告-多项式计算器》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、《数据结构》课程设计报告姓名学号2009级5班7组实验室:A110提交日期8.25成绩指导教师实验题目:多项式计算器问题解析(对问题的分析、理解和解题方法):我们先对数据结构进行了分析,对其运算进行了详细的分解。我们把整个程序我们分为6个部分加减法,乘法,除法,排序整理,多项式解析,输入输出的格式及用户界面。一·1.多元多项式加法:直接加,进行排序整理。2.多元多项式减法即加法的取反运算。3.如何进行解析是一个难点,我们中序表达式转后序表达式的方法进行解析。二·4.多元多项式乘法是前一个多项式的每一项与后一项的每一项相乘相加,然后排序整理。5.由于上述分析中提到对多项式进行排序整理,则我们

2、就要先写一个sort()的函数,对多项式进行排序整理。其原理是按照其中一个字母的次数的降次排序,使用的是冒泡算法。三·6.一元多项式除法即比较前一项与后一项的最高次数,若被除数的最高次数大于等于除数的最高次数,则被除数的用最高次项除以除数的最高次项,得到一个临时的商.再用被除数减去这个商乘以除数的积作为新的被除数。如此循环,就可以得到商。7.一元多项式的模,模就是除法中最后的被除数。8.对整个多项式进行输入输出的界面比较容易设计,但是对多项式的输出格式很难调试,有很多情况(去符号,去0,指数是0的情况等等)。数据结构选择、算法设计:我们用java语言编辑程序,应为它里面含有很多可以直接引用

3、的的方法。多项式用List(线性表)存储,其中每一个节点为一个单项式,单项式内部有系数和指数,系数为一个double型数字,指数用一个TreeMap(可排序映射表)表示,字符串存单项式的字母,对应的值为该字母的指数.多项式内部封装了加减乘除模运算和转换为字符串,作为支持,又封装了getMaxExp(取最高次数),sort(排序整理,去0项),negate(取反).这些计算需要用到单项式的计算,所以也对单项式封装了多种方法。单项式封装了add(加),multiple(乘)divide(除),compareTo(比较),remove0(去除指数为0的项),isN

4、egative(判断是否为负数项),转换为字符串。另外还有解析运算类,用于把字符串解析成多项式和运算符,然后通过多项式类进行运算,这样的好处就是程序入口简单,降低耦合性,便于代码复用.用户界面单独编写,并通过解析运算类进行多项式处理,返回结果。用户界面只有输入框,输出框和一个按钮,用法简单,报错功能完善。1.中缀表达式转后缀表达式:  ·开始扫描;  ·数字和字母时,转换成多项式加入后缀表达式;  ·运算符:  a.若为最高级的运算符,入栈;  b.若为'(',入栈;  c.若为')',则依次把栈中的的运算符加入后缀表达式中,直到出现'(',从栈中删除'(';  d.若为不是最高级的运算符

5、,则将从栈顶到第一个优先级不大于(小于,低于或等于)它的运算符(或'(',但优先满足前一个条件)之间的运算符加入后缀表达式中,该运算符再入栈.2.用后缀表达式计算·构建一个空堆栈,扫描后缀表达式;·多项式时,入栈;·运算符时,从堆栈中弹出两个多项式运算,将结果再次入栈;·最后的栈顶元素就是结果多项式.任务分工及进度计划:任务分工:我的任务是解析字符串,按顺序转换成后缀表达式,并调用多项式的计算.以及编辑多项式的加法和减法运算。进度:我们在8.24下午进行分组,大家讨论整个程序的大体构架,并且进行任务的划分。8.25白天在各自的程序完成后,进行合并以及大量的调试,晚上把输入输出界面编辑出来了

6、,并开始写了各自的实验报告。8.26早上交付程序并提交实验报告。用户手册:1.在用户界面的第一行输入你想要计算的多项式。2.用户要记住多元多项式只能计算加,减,乘法而不能进行除法和模运算;一元多项式可以进行加,减,乘,除,模运算。3.输入完毕后,请检查多项式是否输入错误。4.检查完毕后,请按“计算”按钮,你会在下一行得出你想要运算的多项式的结果。测试结果:1.一元多项式加法:2.一元多项式减法:1.一元多项式乘法:2.一元多项式除法:3.一元多项式模运算:1.多元多项式加法:2.多元多项式减法:3.多元多项式乘法:程序清单:解析并计算:packagepolynomial;importjav

7、a.util.ArrayList;importjava.util.HashSet;importjava.util.List;importjava.util.Set;importjava.util.Stack;publicclassEval{publicPolyeval(Stringexp){Listlist=infixExpToPostExp(exp);//转化成后缀表达式returndoEval(lis

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。