- 1、本文档共2页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
多项式基本运算.doc
多项式基本运算
一.概述
1.程序实现功能:一元多项式基本运算,包括两多项式之间的加减乘除、单个多项式的微分,积分;
2.多项式:多项式为整系数一元多项式,未知数为x,可以包含常数项;
3.编译环境:Virual C++ 6.0。
二. 数据结构和算法设计
1. 数据结构
每个多项式用链表表示,结构形式如下:
typedef struct node
{ int coef_numerator; //系数分子
int coef_denominator; //系数分母
int exp; //指数
struct node *next;
}Node,*Linklist;
结构(联合)说明
系数由分子分母组成,整数系数时分母为1;
经过整理后整个多项式为降幂序列。
2. 主要算法设计
1.多项式的输入:未知数为x,与系数相连,但与指数间通过“^”相隔,整个多项式以“#结束,如:如3x^3-x^2+4x-7#;
2.将输入多项式存入字符型数组str[MAX],存储时略去“^”,最后一位“#”保留,作为多项式结束标志;
3.将数组内数据转换成链表时,每插入一个结点都判断次数,保证每个多项式为降幂;
4.加法:设两个指针分别指向两个链表,同时有哪些信誉好的足球投注网站两个多项式,把第二个多项式中的项整合到第一个多项式中。当第二个指针所指项指数比第一个指针低时,继续有哪些信誉好的足球投注网站第一个多项式,直到第二个指针所指项数等于或大于第一个指针,指数相等时系数相加后释放第二个指针,否则把第二个指针所指项插入到第一个指针之前;
5.减法:将第二个多项式每个系数变反,进行加法操作;
6.乘法:将第二个多项式每一项与第一个多项式相乘,对相乘后的每两个多项式间做加法,直到第二个多项式结束;
7.除法:用被除式最高项除除式得到商式第一项,用这一项与除式相乘,所得式子和被除式做减法(被除式做被减数),得到的新式子作为新的被除数,重复这个过程,直到被除式次数小于除式;
8.微分:原系数与指数相乘作为新的系数,原指数减1作为新的指数;
9.积分:原系数作为分子,原指数加1做分母,分子分母约分;原指数加1作为新的指数;
三. 调试过程说明:
1.因为初期考虑不够周全,多项式按升幂序列。因为除法必须从最高次幂开始计算,所以改动了把多项式从字符形式变成链表的函数,这是比较大的失误之一;
2.未考虑同一个表达式里可能有同次项出现,直到同学提出来,才意识到并作了相应修改;
3.一开始并没有为str[MAX]设立专门的结束标志,以“\0”结束,于是不得不为最后一项编写特定代码,这样不仅增加了代码长度,同时也在无形中增加了出错的几率。以致于后来调试过程中不断修改这一段代码,浪费了不少时间。后来设立了整个字符串的结束标志“#”,就省去了这段代码,减少了程序的冗余,也增强了程序的可读性;
4.在增加了字符串的结束标志“#”后,结果出现了粗心的错误。只为第一个表达式增加而第二个表达式忘了加,结果在用加法调试时,对两个表达式,输入顺序颠倒一下,结果就不同了,为此费了很长时间去跟踪函数执行,等到发现错误真是有种说不出的可笑。
四. 对程序的认识:
1.优点:
(1) 本程序在输入方面跟平时书面表达式的书写很类似,只是为了区分系数和指数增加了标志符“^”。而且在两个表达式都输入后会将两个多项式都按降幂顺序打印,可以让输入者看到两个多项式,个人感觉此种输入优于仅输入系数和指数的输入方式;
(2) 打印方面,跟输入完全一致,系数为分数时会用小括号将分数括住,有助于多项式的观察;
2.不足和有待改进的地方:
(1)时间原因,没有对多项式的输入进行纠错处理。所以程序的容错性比较弱,要求输入正确。
(2)在做乘法运算时,可以做进一步优化。改用递归,将每个多项式分成两个或几个小的多项式,这样可以大大降低时间的复杂性。
您可能关注的文档
- 哈尔滨市科技计划项目经费.doc
- 哈工大院(系)领导班子换届竞争上岗群众(专家)推荐表.doc
- 唐国安纪念学校第12周工作安排.doc
- 唐山市公安交通警察支队见习岗位信息.doc
- 售后服务承诺及培训内容.doc
- 商丘市第二人民医院医用被褥采购项目.doc
- 商品房买卖合同网上登记备案注销申请书.doc
- 喀什市学校管理专项督导调研方案.doc
- 嘉祥2015年电教工作总结.doc
- 嘉顺公司布袋除尘器.doc
- 中国国家标准 GB/T 18233.4-2024信息技术 用户建筑群通用布缆 第4部分:住宅.pdf
- GB/T 18233.4-2024信息技术 用户建筑群通用布缆 第4部分:住宅.pdf
- GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计.pdf
- 《GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计》.pdf
- 中国国家标准 GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计.pdf
- GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置.pdf
- 《GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置》.pdf
- 中国国家标准 GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置.pdf
- GB/T 17889.4-2024梯子 第4部分:铰链梯.pdf
- 《GB/T 17889.4-2024梯子 第4部分:铰链梯》.pdf
文档评论(0)