多项式类的设计与实现(MFC).docVIP

  1. 1、本文档共32页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
多项式类的设计与实现(MFC)

封 皮 题目: 班级: 姓名: 学号: 日期: 课 程 设 计 任 务 书 学院 专业 学生姓名 学号 设计题目 多项式类的设计与实现 内容及要求: 开发多项式类Polynomial,多项式的每一项用链表的结点表示,每项包含一个系数和一个指数。例如:2x4的指数为4,系数为2。请开发一个完整的Polynomial类,包括构造函数、析构函数以及“get”函数(读取值)和“set”函数(设置值)。该类还要提供以下重载的运算符: 重载加法运算符+,将两个多项式相加。 重载加法运算符-,将两个多项式相减。 重载赋值运算符=,将一个多项式赋给另外一个多项式。 重载加法运算符*,将两个多项式相乘。 编写一个主函数测试多项式类的上述功能。 进度安排: 第17周:分析题目,查阅课题相关资料,进行类设计、算法设计; 第18周:程序的设计、调试与实现; 第19周:程序测试与分析,撰写课程设计报告,进行答辩验收。 指导教师(签字): 年 月 日 学院院长(签字) 年 月 日 目 录 1 需求分析 - 1 - 2 算法基本原理 - 1 - 3 类设计 - 2 - 4 详细设计 - 2 - 4.1 类的接口设计 - 2 - 4.2 类的实现 - 3 - 4.3 主函数设计 - 12 - 5 DOS界面程序运行结果及分析 - 14 - 5.1 程序运行结果 - 14 - 5.2运行结果分析 - 15 - 6 基于MFC的图形界面程序开发 - 15 - 6.1 基于MFC的图形界面程序设计 - 15 - 6.2 程序测试 - 27 - 6.3 MFC程序编写总结 - 29 - 7 参考文献 - 29 - 1 需求分析 (1) 开发多项式类Polynomial,多项式的每一项用链表的结点表示,每项包含一个系数和一个指数。例如:2x4的指数为4,系数为2。请开发一个完整的Polynomial类,包括构造函数、析构函数以及“get”函数(读取值)和“set”函数(设置值)。 (2)多项式的定义:n个单项式的代数和叫多项式。 (3)程序测试数据: P1:2x+3x^2+2x^4+3x^2 P2:3x^2+2x^3 (1) 2 算法基本原理 设有2个多项式p1,p2 P1:2x+3x^2+2x^4+3x^2 P2:3x^2+2x^3 实现多项式p1和p2的计算,关键是对p1和p2的指数和系数进行加减生的操作,我们可以先编辑一个基类Polynominal。通过链表和重载运算符的方法来实现。 (1)多项式即个个单项式的和,我们可以把一个多项式分解成一项一项来看,每一项用链表的一个节点表示,每个节点包括一个单项式的系数、指数和指向该节点类型的一个指针。 (2)用Polynominal创建对象p1、p2、p3,通过调用Create(c1,e1,size1)函数来构建多项式。 (3)通过重载+、-、*以及=运算符,对多项式进行操作。 (4)通过p1.Print()来显示结果。 3 类设计 从上面的算法分析可以看到,本设计面临的计算问题的关键是多项式运算。可以定义一个多项式类Polynominal。 (1)该类包括私有数据成员Node *head,Node是构造的节点类型的结构体,包括系数、指数和指向该节点类型的一个指针。 (2)成员函数包括Polynominal()//构造函数, Polynominal(const Polynominal )//拷贝构造函数,~Polynominal()//析构函数Node* get(int e);//读取指数为e的项,返回其指针,void set(double c,int e);//设置指数为e的项的系数为c, void Create(double *c,int *e,int n);//创建多项式,friend Polynominal operator +(Polynominal a,Polynominal b);//重载+运算符,friend Polynominal operator -(Polynominal a,Polynominal b);//重载-运算符,friend Polynominal operator *(Polynominal a,Polynominal b);//重载*运算符,friend ostream operator(ostream os, const Polynominal a);Polynominal operator =(Polynominal a);//重载=运算符,void Print(ostream os = cout) const;//显示函数 void Copy(const Polynominal a)//复制函数 对以上进行

文档评论(0)

shenlan118 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档