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 转换为QByteArray
    strcpy(opt,ba.data());                     //data可以把QByteArray转换为const char *


    //opt[i]还没进栈,看opt优先级与栈顶top的优先级情况,对栈进行操作,之后再操作opt
    while(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.mfbz.cn/a/250047.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

大模型算法工程师的面试题来了(附答案)

自 ChatGPT 在去年 11 月底横空出世&#xff0c;大模型的风刮了整一年。 历经了百模大战、Llama 2 开源、GPTs 发布等一系列里程碑事件&#xff0c;将大模型技术推至无可争议的 C 位。基于大模型的研究与讨论&#xff0c;也让我们愈发接近这波技术浪潮的核心。 最近大模型相关…

Stable Diffusion 微调及推理优化实践指南

随着 Stable Diffsuion 的迅速走红&#xff0c;引发了 AI 绘图的时代变革。然而对于大部分人来说&#xff0c;训练扩散模型的门槛太高&#xff0c;对 Stable Diffusion 进行全量微调也很难入手。由此&#xff0c;社区催生了一系列针对 Stable Diffusion 的高效微调方案&#xf…

动态规划习题

动态规划的核心思想是利用子问题的解来构建整个问题的解。为此&#xff0c;我们通常使用一个表格或数组来存储子问题的解&#xff0c;以便在需要时进行查找和使用。 1.最大字段和 #include <iostream> using namespace std; #define M 200000int main() {int n, a[M], d…

磁盘及文件系统(上)

这次博客我们将重点理解Ext2文件系统。 首先我们要理解什么是文件系统。 在之前我们一直理解的文件都是一个被打开的文件&#xff0c;而os为了能够管理这样的文件创建了struct_file这样的结构体对象在内核中描述被打开的文件&#xff0c;这个结构体对象中包含了被打开文件的基…

C# OpenVINO 直接读取百度模型实现图片旋转角度检测

目录 效果 模型信息 代码 下载 C# OpenVINO 直接读取百度模型实现图片旋转角度检测 效果 模型信息 Inputs ------------------------- name&#xff1a;x tensor&#xff1a;F32[?, 3, 224, 224] --------------------------------------------------------------- Ou…

拖地用什么拖把拖最干净 手持洗地机好用吗?据说拖地又亮又干净?

拖地用什么拖把拖最干净 手持洗地机好用吗&#xff1f;据说拖地又亮又干净&#xff1f; 拖地用什么拖干净&#xff1f;在拖地时&#xff0c;选择合适的拖把和清洁剂非常重要。常见的拖把类型包括胶棉拖把和平板拖把。胶棉拖把易于清洁&#xff0c;适用于硬地板和短毛地毯&#…

c语言->浅学结构体

系列文章目录 文章目录 前言 ✅作者简介&#xff1a;大家好&#xff0c;我是橘橙黄又青&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;橘橙黄又青_C语言,函数,指针-CSDN博客 目的&#xff1a;学习结构体基础内容&am…

电商用户运营优化:腾讯文档API无代码集成

腾讯文档API集成&#xff1a;电商平台无代码客服系统 随着数字化时代的到来&#xff0c;电商平台日益求势于高效率和低成本的运营模式。无代码开发正在改变传统业务流程的构建方式&#xff0c;尤其在客户服务领域&#xff0c;这种转变正变得尤为明显。本文将探索腾讯文档API在…

LeetCode 300最长递增子序列 674最长连续递增序列 718最长重复子数组 | 代码随想录25期训练营day52

动态规划算法10 LeetCode 300 最长递增子序列 2023.12.15 题目链接代码随想录讲解[链接] int lengthOfLIS(vector<int>& nums) {//创建变量result存储最终答案,设默认值为1int result 1;//1确定dp数组&#xff0c;dp[i]表示以nums[i]为结尾的子数组的最长长度ve…

【leetcode】链表总结

说明&#xff1a;本文内容来自于代码随想录 链表基本操作 https://leetcode.cn/problems/design-linked-list/ 删除节点 https://leetcode.cn/problems/remove-linked-list-elements/description/&#xff0c;删除节点&#xff0c;虚拟头节点。定义两个节点&#xff0c;分别…

【算法】选择排序

一、排序逻辑 选择排序逻辑:对数组中的数据,先假定一个最小的数据下标,然后进行循环寻找到最小数据的下标,放在第一层循环的最初始位置 例: 从0 ~ N-1 寻找到最小值,放在0位置 从1~N-1 寻找到最小值 ,放在1位置 从2~N-1 寻找到最小值,放在2位置 。。。 二、code 实…

【MATLAB第82期】基于MATLAB的季节性差分自回归滑动平均模型SARIMA时间序列预测模型含预测未来

【MATLAB第82期】基于MATLAB的季节性差分自回归滑动平均模型SARIMA时间序列预测模型含预测未来 一、模型介绍 1、模型简介 季节性差分自回归移动平均模型&#xff08;Seasonal Autoregressive Integrated Moving Average Model, SARIMA&#xff09;&#xff0c;又称为周期性…

【算法集训】基础数据结构:九、完全二叉树

完全二叉树是二叉树的一种&#xff0c;它是除了叶子节点外其余各节点都为满二叉树&#xff0c;叶子节点只在倒数第一层或第二层出现。 即使是最后一层的叶子节点也是从左到右依次排列&#xff0c;中间不会空。 每一层都是按从左到右的顺序编号&#xff0c;所以一个节点i的叶子节…

C#动态生成带参数的小程序二维码

应用场景 在微信小程序管理后台&#xff0c;我们可以生成下载标准的小程序二维码&#xff0c;提供主程序入口功能。在实际应用开发中&#xff0c;小程序二维码是可以携带参数的&#xff0c;可以动态进行生成&#xff0c;如如下场景&#xff1a; 1、不同参数决定的显示界面不同…

两线制(V/F,I/F)频率脉冲信号转换器

两线制(V/F,I/F)频率脉冲信号转换器 型号&#xff1a;JSD TAF-1021S V/F,I/F频率脉冲信号转换器 型号&#xff1a;JSD TAF-1001S 高端型 型号&#xff1a;JSD TAF-1001D 经济型&#xff0c;价格优惠 新款V/F,I/F频率脉冲信号转换器属升级款&#xff0c;产品从性能&#xf…

科目三 换挡为什么要踩离合器

换挡时需要踩离合器为了切断动力传输&#xff0c;让变速器空转&#xff0c;齿轮才会同步&#xff0c;从而轻松挂挡。 在起步时&#xff0c;当车速达到15km/h时&#xff0c;从一挡换到二挡。 当车速达到25km/h时&#xff0c;可以换成三挡&#xff0c; 达到35km/h左右时&#xf…

不同的葡萄酒瓶盖会影响葡萄酒饮用的体验

首先&#xff0c;不同的葡萄酒瓶盖会影响我们找到想要喝的葡萄酒的难易程度。螺旋盖、Zork瓶塞和起泡酒“蘑菇形瓶塞”赢得了直接的满足感&#xff0c;它们只需要拔瓶塞不需要开瓶器。来自云仓酒庄品牌雷盛红酒分享对于所有其他的酒瓶封口&#xff0c;我们都需要一个工具来打开…

学校校园网站建设的作用如何

如今随着互联网线上便捷化提升&#xff0c;不仅仅是企业&#xff0c;高校或小学、幼儿园等都希望通过线上宣传、展示内容、提升服务效率、赋能更好的完善工作内容。 学校在宣传方面主要体现在招生&#xff0c;很多学校都会在每年发出大量广告用于招生&#xff0c;然而传统纸质…

IDEA——还在手动new对象set值嘛,GenerateAllSetter插件帮你解决!!!

IDEA插件 一、GenerateAllSetter插件介绍二、如何下载安装三、如何使用 总结 最近项目上有些测试需要有很多属性&#xff0c;而且大部分的属性都是要设置值的&#xff0c;一个一个手动set设值很繁琐&#xff0c;就想着有没有能解决这个问题的办法&#xff0c;就发现了一个非常好…

运营微信视频号要注意哪些问题?

视频号运营的5个雷点你别踩! 今天和你说的视频号运营的5大雷点 你踩过没? 这5点虽然和野花似的 但也不能踩哦 雷点1:违规行为 雷点2:抄袭剽窃 雷点3:没有明确目标受众 雷点4:短视频质量过低 雷点5:缺少社交互动 相信不管是视频号还是别的平台都通用哈
最新文章