MFC版链表实现稀疏多项式相加减

链表实现多项式运算(加减)MFC可视化版

题目

设计一个一元稀疏多项式简单计算器。

基本要求

(1)输入并建立两个多项式;
(2)多项式a与b相加,建立和多项式c;
(3)多项式a与b相减,建立差多项式d;
(4)输出多项式a, b, c, d。输出格式:比如多项式a为:A(x)=c1xe1+ c2xe2+…+ cmxem,其中,ci和ei分别为第i项的系数和指数,且各项按指数的升幂排列,即0≤e1<e2<…<em。

实现提示

(1)用带头结点的单链表存储多项式。
(2)每个多项式链表中都只存储非零系数项。若多项式a与b中指数相等的两项相加/减后,系数为零,则在和/差多项式中不存储该指数项。

思路

其实说真的,看到链表就烦,没办法了,只能写了,无奈自己太菜,大部分代码还是用的书上的,不过再运算符重载的时候自己改动了一下,因为要MFC可视化的缘故,就把输入输出的重载删掉了。
大致就和老师说的一样,重点在于建立多项式类,难点在于MFC可视化的计算器界面的数据输入输出,当然方法肯定很多,代码比较糙,将就着看吧,希望有对你有用的部分。
样子差不多就是这样:
bsYCN6l.png
输入
uYOKSLI.png
输出
lniru1w.png

1)输入数据处理

输入时,用CString变量存编辑框的内容,同时具备按钮输入和键盘输入两种方法,时间比较急,没有检测非法输入,必须是合法输入才能运算。不过这个写起来也不难,完成作业就先这样吧,到时候要是她还有要求再说。先把所有输入存在串里,然后用函数分割开,存进多项式对象里,在分割时写了一个函数,感觉蛮好用的,这里还有一个操作可能比较多于,先用CString存,在取数据的时候又转换为string,对string熟一点。
按键输入代码:

void CCalculatorDlg::OnBnClickedButton1()
{UpdateData(TRUE);m_Str += "1";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButton0()
{UpdateData(TRUE);m_Str += "0";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButtonNod()
{UpdateData(TRUE);m_Str += ".";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButton2()
{m_Str += "2";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButton3()
{UpdateData(TRUE);m_Str += "3";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButton4()
{UpdateData(TRUE);m_Str += "4";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButton5()
{m_Str += "5";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButton6()
{UpdateData(TRUE);m_Str += "6";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButton7()
{UpdateData(TRUE);m_Str += "7";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButton8()
{UpdateData(TRUE);m_Str += "8";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButton9()
{m_Str += "9";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButtonadd()
{UpdateData(TRUE);m_Str += "+";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButtonsub()
{UpdateData(TRUE);m_Str += "-";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButtonx()
{m_Str += "X";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButtonleft()
{UpdateData(TRUE);m_Str += "(";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButtonright()
{UpdateData(TRUE);m_Str += ")";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButtonmul()
{UpdateData(TRUE);m_Str += "^";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}void CCalculatorDlg::OnBnClickedButtonClear()
{m_Str = "";UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}

分割系数和指数函数:pos是开始时的串数组下标,exp是指数,返回系数

float Search_Num(string a,int &pos,int&exp) {float num = 0;int cap = 0;for (int i(pos); i < a.size(); i++) {if (a[i] >= '0'&&a[i] <= '9') {if (cap == 0)num = num * 10 + a[i] - '0';else num = num + (a[i] - '0')*pow(0.1, cap++);}else if (a[i] == '.') {cap = 1;}else {pos = i;break;}}exp = 0;int tag = 1;if (num == 0)num = 1;if (a[pos] == 'X') {if (pos > a.size() -1||a[pos+1]=='-'||a[pos+1]=='+') {exp = 1;pos++;return num;}if (a[pos + 2] == '-') {tag = -1;pos++;}for (int i(pos + 2); i < a.size(); i++) {if (a[i] >= '0'&&a[i] <= '9') {exp= exp* 10 + a[i] - '0';}else { pos = i;exp *= tag;return num;}}}else {exp = 0;return num;}
}

2)存进多项式对象中

类实现:

#include<iostream>
#include<string>
#include<cmath>
const double EXP = 1e-4;
using namespace std;
struct Term {float coef;int exp;Term *link;Term(float a, int b, Term* c = NULL) {coef = a;exp = b;link = c;}Term *insertAfter(float a, int b);
};
Term *Term::insertAfter(float a, int b) {link = new Term(a, b, link);return link;
}
class Poly {
private:Term *first;public:Poly() {first = new Term(0, -1);}Poly(Poly&R);int maxOrder();Term *GetHead() {return first;}string GetString();Poly operator+(Poly&);Poly operator-(Poly&);
};
Poly::Poly(Poly &R) {first = new Term(0, -1);Term *destptr = first, *srcptr = R.GetHead()->link;while (srcptr != NULL) {destptr->insertAfter(srcptr->coef, srcptr->exp);srcptr = srcptr->link;destptr = destptr->link;}
}
int Poly::maxOrder() {Term *current = first;while (current->link != NULL) {current = current->link;}return current->exp;
}
string Poly::GetString()
{string s;CString str;Term *p = GetHead()->link;bool flag = false;while (p != NULL) {str.Format(_T("%.5lf"), p->coef);if (flag == true) {if (p->coef >0) {s += '+';}}flag = true;while (str[str.GetLength() - 1] == '0') {str.Delete(str.GetLength() - 1, 1);}if (str[str.GetLength() - 1] == '.') {str.Delete(str.GetLength() - 1, 1);}if(p->exp==0||(str!=_T("1")&&str!=(_T("-1"))))s += (CT2A)str;else if (str == _T("-1")) {s += '-';}if (p->exp == 1) {s += 'X';}else if(abs(p->exp)>1)s += "X^";str.Format(_T("%d"), p->exp);if (abs(p->exp) > 1) {s += (CT2A)str;}p = p->link;}return s;
}
Poly Poly::operator+(Poly&R) {Term*pa, *pb, *pc, *p;Poly C;float temp;pc = C.first;pa = GetHead()->link;pb = R.GetHead()->link;while (pa != NULL && pb != NULL) {if (pa->exp == pb->exp) {temp = pa->coef + pb->coef;if (abs(temp) > EXP) {pc = pc->insertAfter(temp, pa->exp);}pa = pa->link;pb = pb->link;}else if (pa->exp < pb->exp) {pc = pc->insertAfter(pa->coef, pa->exp);pa = pa->link;}else {pc = pc->insertAfter(pb->coef, pb->exp);pb = pb->link;}}p = pa == NULL ? pb : pa;while (p != NULL) {pc = pc->insertAfter(p->coef, p->exp);p = p->link;}return C;
}
Poly Poly::operator-(Poly&R) {Term*pa, *pb, *pc, *p;Poly C;float temp;pc = C.first;pa = GetHead()->link;pb = R.GetHead()->link;while (pa != NULL && pb != NULL) {if (pa->exp == pb->exp) {temp = pa->coef - pb->coef;if (abs(temp) > EXP) {pc = pc->insertAfter(temp, pa->exp);}pa = pa->link;pb = pb->link;}else if (pa->exp < pb->exp) {pc = pc->insertAfter(pa->coef, pa->exp);pa = pa->link;}else {pc = pc->insertAfter(-pb->coef, pb->exp);pb = pb->link;}}p = pa == NULL ? pb : pa;int flag = pa == NULL ? -1 : 1;while (p != NULL) {pc = pc->insertAfter(flag*p->coef, p->exp);p = p->link;}return C;
}

按等于按钮开始读数据存进多项式A,B中:

void CCalculatorDlg::OnBnClickedButtonCal()
{UpdateData(TRUE);string s = (CT2A)m_Str;if (s.empty()) {AfxMessageBox(_T("请输入表达式!"));return;}Poly A, B,C;bool flag = false;float num = 0;int cap = 0;int v = 1;int pos_B;for (int i(0); i < s.size(); i++) {if (s[i] == ')') {pos_B = i;break;}}int p = 0;if (s[0] == '(')p++;bool real = true;Term *rear = A.GetHead();while (p < pos_B) {real = true;if (s[p] == '+') {real = true;p++;}else if (s[p] == '-'){real = false;p++;}int temp_e;num=Search_Num(s, p,temp_e);v = real == true ? 1 : -1;rear = rear->insertAfter(v*num, temp_e);}p += 3;rear = B.GetHead();while (p < s.size()-1) {real = true;if (s[p] == '+') {real = true;p++;}else if (s[p] == '-') {real = false;p++;}int temp_e;num = Search_Num(s, p, temp_e);v = real == true ? 1 : -1;rear = rear->insertAfter(v*num, temp_e);}if (s[pos_B + 1] == '+') {C = A + B;}else {C = A - B;}string temp = C.GetString();m_Str = temp.c_str();UpdateData(FALSE);// TODO: 在此添加控件通知处理程序代码
}

3)结果转换位字符串更新到Edit框中

转字符串的函数就在类定义里面,也费了不少功夫,因为样例给的情况太全面了,刚开始没考虑到负指数,不过不要紧,还是改好了。面向对象的特点体现以后更改代码也比较方便~

后记

代码没有写注释,故意的。对,故意的。能理解的小伙伴应该能看懂,完全不懂的就有点困难了,相比不可视化,可视化对于输入和输出需要转化一下,其他的和不普通的差不多,当然写按钮也比较烦,,,
界面很丑,之后可能会美化,再说吧,今天先睡了。
2018/11/13 23:42:48

转载于:https://www.cnblogs.com/Titordong/p/9955642.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/412833.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WindTerm导出会话

WindTerm的session配置并无法被适用于其他软件中&#xff0c;所有的session保存在WindTerm安装路径下的profiles文件夹内&#xff0c;如果需要更新版本或回退&#xff0c;将所安装的版本覆盖即可&#xff0c;或是将profiles复制于新路径下。 图标闪烁设置、会话保存-导入导出 …

[官方] mysql 性能优化文档(中英文自译)

大家好&#xff0c;我是烤鸭&#xff1a; 根据官方文档翻译并精简部分内容。建议有时间的朋友下载原版查看&#xff0c;全文106页pdf&#xff0c;快的话1-2天就能看完。自己翻译的有些地方可能不完整&#xff0c;欢迎指正。官方pdf下载&#xff0c;需登录&#xff1a;https://w…

使用wiki.js部署团队知识库

1.安装NODE.JS 参考教程 https://xie.infoq.cn/article/6820ea5b625f4e163ccb76cec 1.1 下载nodejs安装包 http://nodejs.cn/download/ 1.2 上传到服务器soft目录后进行解压 # 解压 tar -xf node-v16.18.0-linux-x64.tar.xz # 删除安装包 rm -rf node-v16.18.0-linux-x64.ta…

系统架构设计师-软件水平考试(高级)-理论-操作系统

系统架构设计师-操作系统 前言&#xff1a; 之前文章发布后&#xff0c;发现还是有一定阅读量的&#xff0c;所以决定继续发一些思维导图。 思维导图首先以思维结构为主&#xff0c;其次以考试的内容进行一定的改动&#xff08;如本次&#xff0c;将“嵌入系统”放在了“操作系…

关于我的代码在课上第一时间没有运行出来这件事

日期&#xff1a;2018.11.15 博客期&#xff1a;024 星期四 今天上课老师又出题了&#xff0c;这次的题目是去利用文件的读写去完成文件的读写答题&#xff01;那为什么我没有第一时间做出来呢&#xff1f;原因我分析了以下几点&#xff1a; 1、我第一时间对题意没有准确的审视…

pytest+allure生成漂亮的报告+显示

一&#xff1a;环境准备 1.python3.62.windows环境3.pycharm4.pytest-allure-adaptor5.allure2.8.06.java1.8pytest-allure-adaptor快速安装 在cmd中输入 pip install pytest-allure-adaptor&#xff0c;回车 二&#xff1a;报告生成 第1步&#xff1a;下载allure.zip&#xff…

PC网页js调用本地应用程序

最近要现实一个在PC网页中实现点击按钮调用本地应用程序的功能 其实实现原理也非常简单&#xff0c; 首先注册一个本地注册表文件&#xff0c;指向本地应用程序路径 其次在网页中用js指向这个注册表文件&#xff0c;就可以实现网页调用本地应用程序 Windows Registry Editor V…

springboot 多数据源 读写分离 AOP方式

大家好&#xff0c;我是烤鸭&#xff1a; 今天分享springboot读写分离配置。 环境&#xff1a; springboot 2.1.0.RELEASE 场景说明&#xff0c;目前的需求是 读数据源 * 2 写数据源 * 1 1. 配置文件 application.yml server:port: 8085 spring:application:name: test-d…

201771010137 赵栋 《第十二周学习总结》

一&#xff1a;理论部分 1.&#xff08;1&#xff09; 用户界面(User Interface)用户与计算机系统(各种程序)交互的接口 &#xff08;2&#xff09;图形用户界面(Graphical User Interface)以图形方式呈现的用户界面 2.AWT:Java 的抽象窗口工具箱&#xff08; Abstract WindowT…

多服务器 elk 搭建 [elasticsearch 7.0 ]

大家好&#xff0c;我是烤鸭&#xff1a; 今天分享一下多服务器的elk搭建。 1. 流程规划 2. 执行搭建 最新的版本和对应下载地址可以在官网查询到 https://www.elastic.co/cn/products/ 2.1 elasticsearch 7.0 搭建 2.1.1 下载 wget https://artifacts.elastic.co/…

知乎问答:现在程序员的工资是不是被高估了?

对于优秀的程序员来说&#xff0c;薪酬的天花板犹如发际线&#xff0c;没有最高只有更高。而对于只想「混日子」的程序员来说&#xff0c;高薪很可能是泡沫&#xff0c;风一吹就碎。 一、程序员的工资真的高吗&#xff1f; 《2018年中国程序员生存状况报告》&#xff0c;来源&a…

lombok 的bug?lombok 导致 springmvc 使用 @RequestBody注解 接收 json数据 对象参数绑定失败

大家好&#xff0c;我是烤鸭&#xff1a; lombok 导致 springmvc 使用 RequestBody注解 接收 json数据 对象参数绑定失败。 环境版本&#xff1a; spring 5.x 1. 场景复现 问题出现在创建对象的属性名称。比如我有一个类中的属性值是 String aTest; 首字…

web APIS

WEB API系列&#xff1a; 很多人都很迷惑&#xff0c;既然有了WCF为什么还要有WEB API&#xff1f;WEB API会不会取代WCF&#xff1f; 就我的看法&#xff0c;WCF提供的是一种RPC实现的集合&#xff0c;WCF的设计更多地考虑了SOA的场景&#xff0c;以及各种RPC的问题。很多人也…

dubbo 整合 zipkin,最简单的方式,亲测有效

大家好&#xff0c;我是烤鸭。 之前也试过网上很多版本&#xff0c;看了好多文章。现在分享最简单的方式&#xff0c;代码侵入性最小的。 1. 修改pom,引入jar。 <!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc --> <dependency><…

[Network Architecture]DPN(Dual Path Network)算法详解(转)

https://blog.csdn.net/u014380165/article/details/75676216 论文&#xff1a;Dual Path Networks 论文链接&#xff1a;https://arxiv.org/abs/1707.01629 代码&#xff1a;https://github.com/cypw/DPNs MXNet框架下可训练模型的DPN代码&#xff1a;https://github.com/m…

javax.script.ScriptException: ReferenceError: xxx is not defined in eval

大家好&#xff0c;我是烤鸭&#xff1a; 今天使用 javax.script.ScriptEngine 遇到一个奇怪的问题&#xff0c;无法识别js方法。 1. 报错内容&#xff1a; javax.script.ScriptException: ReferenceError: "a" is not defined in <eval> at line number…

Python的特殊成员

Python 用下划线作为变量前缀和后缀指定特殊变量 _xxx 不能用’from module import *’导入 __xxx__ 系统定义名字 __xxx 类中的私有变量名 核心风格&#xff1a;避免用下划线作为变量名的开始。 现在我们来总结下所有的系统定义属性和方法&#xff0c; 先来看下保留属性&#…

java 实现 常见排序算法(四)基数排序

大家好&#xff0c;我是烤鸭&#xff1a; 今天分享一下基础排序算法之基数排序。 1. 基数排序&#xff1a; 原理&#xff1a;基数排序&#xff08;radix sort&#xff09;属于“分配式排序”&#xff08;distribution sort&#xff09;&#xff0c;又称“桶子法”&#…

今天分享一下做支付宝小程序遇到的坑。ISV权限不足,建议在开发者中心检查对应功能是否已经添加。验签出错,建议检查签名字符串或签名私钥与应用公钥是否匹配

大家好&#xff0c;我是烤鸭&#xff1a; 今天分享一下做支付宝小程序遇到的坑。pom版本 <!-- https://mvnrepository.com/artifact/com.alipay.sdk/alipay-sdk-java --><dependency><groupId>com.alipay.sdk</groupId><artifactId>alipay-sdk-j…

Will not attempt to authenticate using SASL | dubbo项目启动特别慢,拉取 zookeeper 服务日志打印特别慢

大家好&#xff0c;我是烤鸭&#xff1a; 今天分享一下使用dubbo遇到的几个问题。 1. cause: KeeperErrorCode ConnectionLoss for /dubbo/ xxx 异常如下&#xff1a; pid9965&qos.accept.foreign.ipfalse&qos.enabletrue&qos.port10887&timestamp1567…