QT实现四则运算计算器


#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);this->setMaximumSize(240,300);this->setMinimumSize(240,300);this->setWindowTitle("计算器");QFont f("仿宋",14);ui->lineEdit->setFont(f);//按钮上放图片
//    QIcon icon=("D:\\");
//    ui->back->setIcon(icon);//改变按钮背景颜色ui->equal->setStyleSheet("background:green");}Widget::~Widget()
{delete ui;
}void Widget::on_btn0_clicked()
{expression+="0";ui->lineEdit->setText(expression);
}void Widget::on_btn1_clicked()
{expression+="1";ui->lineEdit->setText(expression);
}void Widget::on_btn2_clicked()
{expression+="2";ui->lineEdit->setText(expression);
}void Widget::on_btn3_clicked()
{expression+="3";ui->lineEdit->setText(expression);
}void Widget::on_btn4_clicked()
{expression+="4";ui->lineEdit->setText(expression);
}void Widget::on_btn5_clicked()
{expression+="5";ui->lineEdit->setText(expression);
}
void Widget::on_btn6_clicked()
{expression+="6";ui->lineEdit->setText(expression);
}
void Widget::on_btn7_clicked()
{expression+="7";ui->lineEdit->setText(expression);
}
void Widget::on_btn8_clicked()
{expression+="8";ui->lineEdit->setText(expression);
}
void Widget::on_btn9_clicked()
{expression+="9";ui->lineEdit->setText(expression);
}
void Widget::on_add_clicked()
{expression+="+";ui->lineEdit->setText(expression);
}void Widget::on_sub_clicked()
{expression+="-";ui->lineEdit->setText(expression);
}void Widget::on_mul_clicked()
{expression+="*";ui->lineEdit->setText(expression);
}void Widget::on_div_clicked()
{expression+="/";ui->lineEdit->setText(expression);
}void Widget::on_clear_clicked()
{expression.clear();ui->lineEdit->clear();
}void Widget::on_back_clicked()
{expression.chop(1);ui->lineEdit->setText(expression);
}void Widget::on_left_clicked()
{expression+="(";ui->lineEdit->setText(expression);
}void Widget::on_right_clicked()
{expression+=")";ui->lineEdit->setText(expression);
}void Widget::on_equal_clicked()
{QStack<int> s_num,s_opt;char opt[128]={0};int i=0,temp=0,num1,num2;QByteArray ba=expression.toLocal8Bit();     //QString 转换为QByteArraystrcpy(opt,ba.data());                     //data可以把QByteArray转换为const char *//opt[i]还没进栈,看opt优先级与栈顶top的优先级情况,对栈进行操作,之后再操作optwhile(opt[i]!='\0'||s_opt.empty()!=true){if(opt[i]>='0'&&opt[i]<='9')                //操作数{temp=temp*10+opt[i]-'0';i++;if(opt[i]<'0'||opt[i]>'9'){s_num.push(temp);temp=0;}}else                                            //操作符{if(s_opt.empty()==true||                            //操作符入栈情况Priority(opt[i])>Priority(s_opt.top())||       //1、将要入栈的操作符比栈顶操作符优先级大(s_opt.top()=='('&&opt[i]!=')'))               //2、已经有(入栈,将要入栈的不是)而是其他()的操作符{                                                   //3、操作符栈为空s_opt.push(opt[i]);i++;continue;}if(s_opt.top()=='('&&opt[i]==')')           //(!opt){                                           //处理完()内的运算符,剩余(),则直接出栈(s_opt.pop();i++;continue;}if(Priority(opt[i])<=Priority(s_opt.top())||        //操作符出栈,i无++(opt[i]==')'&&s_opt.top()!='(')||               //1、将要入栈的操作符比栈顶操作符优先级小,则先计算已在栈中的(opt[i]=='\0'&&s_opt.empty()!=true)             //2、将要入栈的操作符为),则计算()内的运算符)                                               //3、没有要进行入栈的操作符了{char ch=s_opt.top();s_opt.pop();switch(ch){case '+':num1=s_num.top();s_num.pop();num2=s_num.top();s_num.pop();s_num.push(num1+num2);break;case '-':num1=s_num.top();s_num.pop();num2=s_num.top();s_num.pop();s_num.push(num1-num2);break;case '*':num1=s_num.top();s_num.pop();num2=s_num.top();s_num.pop();s_num.push(num1*num2);break;case '/':num1=s_num.top();s_num.pop();num2=s_num.top();s_num.pop();s_num.push(num1/num2);break;}}}}ui->lineEdit->setText(QString::number(s_num.top()));expression.clear();}int Widget::Priority(char ch)
{switch(ch){case '(':return 3;case '*':case '/':return 2;case '+':case '-':return 1;default:return 0;}
}

 

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

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

相关文章

node.js mongoose简述

目录 官方文档 mongoose Schema Model Query document 关系 官方文档 Mongoose v8.0.3: Getting Started mongoose Mongoose 是一个 Node.js 环境下 MongoDB 的对象建模工具。它提供了一种在应用程序中与 MongoDB 数据库进行交互的方式&#xff0c;使得开发者能够使用…

NoSQL 数据库有哪些典型应用?

前面的内容介绍了数据库读写分离和分库分表相关知识&#xff0c;都是针对关系型数据库的&#xff0c;即通常说的 RDBMS。除了关系型数据库&#xff0c;NoSQL 在项目开发中也有着越来越重要的作用&#xff0c;与此同时&#xff0c;NoSQL 相关的内容也是面试的常客。今天我们一起…

计算机网络技术的应用探讨

一、计算机网络技术的概念与主要功能 计算机网络技术指的是将计算机与传输介质连接在 一起&#xff0c;并根据规定的网络协议进行数据通信&#xff0c;从而实现 数据资源共享的一种技术。计算机网络技术的主要功能 包括以下三点。第一&#xff0c;计算机网络技术具有通信功能&a…

如何进行软件测试和测试驱动开发(TDD)?

1. 软件测试概述 1.1 什么是软件测试&#xff1f; 软件测试是一种评估系统的过程&#xff0c;目的是发现潜在的错误或缺陷。通过对软件进行测试&#xff0c;开发者和测试人员可以确定软件是否符合预期的需求、功能是否正常运行&#xff0c;以及系统是否足够稳定和可靠。 1.2…

函数难题:排列

给定一个整数 n&#xff0c;将数字 1∼n 排成一排&#xff0c;将会有很多种排列方法。 现在&#xff0c;请你按照字典序将所有的排列方法输出。 输入格式 共一行&#xff0c;包含一个整数 n。 输出格式 按字典序输出所有排列方案&#xff0c;每个方案占一行。 数据范围 …

【Linux】驱动

驱动 驱动程序过程 系统调用 用户空间 内核空间 添加驱动和调用驱动 驱动程序是如何调用设备硬件 驱动 在计算机领域&#xff0c;驱动&#xff08;Driver&#xff09;是一种软件&#xff0c;它充当硬件设备与操作系统之间的桥梁&#xff0c;允许它们进行通信和协同工作。驱动程…

[已解决】uniapp内置插件,editor富文本报错(附quill.min.js、image-resize.min.js文件)

在使用uni-app运行内置插件editor时&#xff0c;无法输入内容&#xff0c;控制台报错 原因&#xff1a;查看官网得知&#xff0c;需动态引入quill.min.js、image-resize.min.js文件 解决方法&#xff1a; 1.下载quill.min.js、image-resize.min.js到项目static/eidtor文件中 链…

云原生之深入解析Kubernetes Operator的最佳实践和最常见的问题分析

一、Kubernetes Operator 简介 Kubernetes Operator 是通过连接主 API 并 watch 时间的一组进程&#xff0c;一般会 watch 有限的资源类型。当相关 watch 的 event 触发的时候&#xff0c;operator 做出响应并执行具体的动作。这可能仅限于与主 API 交互&#xff0c;但通常会涉…

从零开始搭建Go语言开发环境

https://www.liwenzhou.com/posts/Go/install_go_dev/ “go 命令现在默认在模块感知模式下构建包&#xff0c;即使没有 go.mod 存在也是如此。 “您可以将 GO111MODULE 设置为 auto&#xff0c;仅当当前目录或任何父目录中存在 go.mod 文件时&#xff0c;才能启用模块感知模式…

Linux下FFmepg使用

1.命令行录一段wav,PCM数据 ffmpeg -f alsa -i hw:0,0 xxx.wav//录制 ffplay out.wav//播放ffmpeg -f alsa -i hw:0,0 -ar 16000 -channels 1 -f s16le 1.pcm ffplay -ar 16000 -channels 1 -f s16le 1.pcm -ar freq 设置音频采样率 -ac channels 设置通道 缺省为1 2.将pcm…

uniapp组件map地图组件使用

在uniapp中&#xff0c;可以使用uni-app官方提供的map组件来实现地图功能。下面是一个简单的使用示例&#xff1a; 在页面中引入map组件&#xff0c;在template中添加以下代码&#xff1a; <template><view><!-- map组件 --><map :longitude"longi…

03 动态渲染数据

概述 One of the most used terms and reactive elements used when constructing Vue components is data properties. These manifest themselves within the data() function of a Vue instance: 数据属性是构建 Vue 组件时最常用的术语和反应式元素之一。这些属性体现在 …

Kubernetes实战(十四)-k8s高可用集群扩容master节点

1 单master集群和多master节点集群方案 1.1 单Master集群 k8s 集群是由一组运行 k8s 的节点组成的&#xff0c;节点可以是物理机、虚拟机或者云服务器。k8s 集群中的节点分为两种角色&#xff1a;master 和 node。 master 节点&#xff1a;master 节点负责控制和管理整个集群…

PyTorch官网demo解读——第一个神经网络(1)

神经网络如此神奇&#xff0c;feel the magic 今天分享一下学习PyTorch官网demo的心得&#xff0c;原来实现一个神经网络可以如此简单/简洁/高效&#xff0c;同时也感慨PyTorch如此强大。 这个demo的目的是训练一个识别手写数字的模型&#xff01; 先上源码&#xff1a; fr…

华为云CodeArts Pipeline常见问答汇总

1.【Pipeline】CodeArts Pipeline流水线如何传递参数至CodeArts Build编译构建任务 答参考文档 https://support.huaweicloud.com/pipeline_faq/pipeline_faq_0004.html https://support.huaweicloud.com/usermanual-pipeline/pipeline_10_0005.html https://support.hu…

Composer 安装与使用

Composer 是 PHP 的一个依赖管理工具。我们可以在项目中声明所依赖的外部工具库&#xff0c;Composer 会帮你安装这些依赖的库文件&#xff0c;有了它&#xff0c;我们就可以很轻松的使用一个命令将其他人的优秀代码引用到我们的项目中来。 Composer 默认情况下不是全局安装&a…

vue3 element-plus 日期选择器 el-date-picker 汉化

vue3 项目中&#xff0c;element-plus 的日期选择器 el-date-picker 默认是英文版的&#xff0c;如下&#xff1a; 页面引入&#xff1a; //引入汉化语言包 import locale from "element-plus/lib/locale/lang/zh-cn" import { ElDatePicker, ElButton, ElConfigP…

西南科技大学数据库实验二(表数据插入、修改和删除)

一、实验目的 &#xff08;1&#xff09;学会用SQL语句对数据库进行插入、修改和删除数据操作 &#xff08;2&#xff09;掌握insert、update、delete命令实现对表数据插入、修改和删除等更新操作。 二、实验任务 创建数据库&#xff0c;并创建Employees表、Departments表和…

Python学习笔记第七十五天(OpenCV图像应用)

Python学习笔记第七十五天 OpenCV图像应用读取图片显示图像写入图像保存图像 后记 OpenCV图像应用 读取图片 使用OpenCV读取图片非常简单&#xff0c;可以使用cv2.imread()函数。该函数接受两个参数&#xff1a;图像路径和标志。标志指定了读取图像的方式&#xff0c;包括是否…

MySQL5.x和8.0

区别1. 性能&#xff1a;MySQL 8.0 的速度要比 MySQL 5.7 快 2 倍 MySQL 8.0 在以下方面带来了更好的性能&#xff1a;读/写工作负载、IO 密集型工作负载、以及高竞争&#xff08;"hot spot"热点竞争问题&#xff09;工作负载2. NoSQL&#xff1a;MySQL 从 5.7 版本开…