当前位置: 首页 > article >正文

【数据结构-表达式解析】【hard】力扣224. 基本计算器

给你一个字符串表达式 s ,请你实现一个基本计算器来计算并返回它的值。

注意:不允许使用任何将字符串作为数学表达式计算的内置函数,比如 eval() 。

示例 1:
输入:s = “1 + 1”
输出:2

示例 2:
输入:s = " 2-1 + 2 "
输出:3

示例 3:
输入:s = “(1+(4+5+2)-3)+(6+8)”
输出:23

在这里插入图片描述

class Solution {
public:
    int calculate(string s) {
        int n = s.size();
        stack<int> st;
        st.push(1);
        int ret = 0;
        int sign = 1;
        int i = 0;
        while(i < n){
            if(s[i] == ' '){
                i++;
            }
            else if(s[i] == '('){
                st.push(sign);
                i++;
            }
            else if(s[i] == '+'){
                sign = st.top();
                i++;
            }
            else if(s[i] == '-'){
                sign = -st.top();
                i++;
            }
            else if(s[i] == ')'){
                st.pop();
                i++;
            }
            else{
                long num = 0;
                while(i < n && s[i] >= '0' && s[i] <= '9'){
                    num = num * 10 + s[i] - '0';
                    i++;
                }
                ret += sign * num;
            }
        }
        return ret;
    }
};

时间复杂度:O(n),其中 n 为字符串 s 的长度。需要遍历字符串 s 一次,计算表达式的值。

空间复杂度:O(n),其中 n 为字符串 s 的长度。空间复杂度主要取决于栈的空间,栈中的元素数量不超过 n。

这种题目第一时间就想到用栈来做,这道题的难点是什么呢?我认为这道题有两个问题只要理清就可以。

第一个需要解决的问题是,在算式中我们存在括号,我们怎么样在含有括号的情况下,将括号拆开然后正确计算?比如说在(1-(2-1))中,实际上可以拆解成1-2+1,所以我们可以发现,括号内的符号拆解后,受到括号外符号的影响。

所以我们可以构建一个栈st来储存符号,我们初始化符号sign(1或-1)为1,当我们遍历字符串的时候,遇到左括号,就往栈中推入sign,推入的sign会位于栈顶,作用于这个左括号开始到右括号结束之间的符号,假设我们这时候sign是-1,然后遇到了一个左括号,然后接着在这个括号范围内遇到了一个减号,那么他就将sign变为1,也就是我们所说的负负得正,接着当我们遇到右括号的时候,就弹出栈顶的sign,因为栈顶的sign只作用于这个括号范围。

第二个问题是题目中的数字可能不止是个数,可能是十位、百位或者更多位,所以我们需要用一个while循环来将多个字符转化为一个数字。


http://www.kler.cn/a/407637.html

相关文章:

  • 【深度学习之回归预测篇】 深度极限学习机DELM多特征回归拟合预测(Matlab源代码)
  • 密码学11
  • Python 使用 Token 认证方案连接 Kubernetes (k8s) 的详细过程
  • 大数据基于Spring Boot的化妆品推荐系统的设计与实现
  • HBase Java基础操作
  • Git 提交的相对引用
  • python中的map、split、join函数的作用 => ACM输入输出流
  • 机器翻译 数据集 (NLP基础 - 预处理 → tokenize → 词表 → 截断/填充 → 迭代器) + 代码实现 —— 笔记3.9《动手学深度学习》
  • 从零开始配置Qt+VsCode环境
  • 图的邻接矩阵和邻接表存储
  • 常见协议及其功能
  • c++ chrono 时间统计
  • 11.22 日校内模拟赛总结 + 题解(矩阵加速dp, 分块)
  • 【论文速读】| RobustKV:通过键值对驱逐防御大语言模型免受越狱攻击
  • vue3中如何上传文件到腾讯云的桶(cosbrowser)
  • zotero7 插件使用
  • 瑞佑液晶控制芯片RA6807系列介绍 (三)软件代码详解 Part.10(让PNG图片动起来)完结篇
  • Linux:自定义Shell
  • --- 文件IO java ---
  • 【Linux驱动开发】irq中断配置API及中断应用 阻塞休眠和非阻塞的驱动操作
  • python安装包中的一些问题(三):加载 matplotlib 的过程中,调用了 Pillow(PIL 库)时发生了错误
  • 解决mfc100u.dll缺失问题,轻松恢复系统稳定
  • 【网格图】【刷题笔记】【灵神题单】
  • Docker Seata分布式事务保护搭建 DB数据源版搭建 结合Nacos服务注册
  • 【Linux】文件IO的系统接口 | 文件标识符
  • AutoDL安装docker问题