【栈】| 力扣高频题: 基本计算器二

2024-08-30 20:52
文章标签 力扣 基本 高频 计算器

本文主要是介绍【栈】| 力扣高频题: 基本计算器二,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

🎗️ 主页:小夜时雨
🎗️专栏:算法题
🎗️如何活着,是我找寻的方向

优雅

目录

  • 1. 题目解析
  • 2. 代码

1. 题目解析

题目链接: https://leetcode.cn/problems/basic-calculator-ii/description/ (可点击)

在这里插入图片描述

本道题是的经典应用问题:表达式求值问题, 我们依旧是采取栈 + 分类讨论的方式。

解决思路:

利用栈来模拟计算过程,中间用到分类讨论

  1. 初始化一个操作符字符为 ‘+’, 为了统一操作,想法:把所有处理过的数字,全部放到栈中,而且栈中的数只需要最后相加就是最后答案。
  2. 分情况讨论: 遍历字符串,题目中还有空格,遇到空格直接跳过。
  3. 遇到操作符,不做其他操作,直接更新操作符变量,遍历下一个。因为我们是遇到数字的时候才会进行计算和入栈。
  4. 遇到数字,有可能是一个多位数的数字,所以要先提取出数字。
  • 判断这个数字前的操作符是什么,来进行入栈操作。
  • 是 ‘+’, 数字直接入栈即可
  • 是 ‘-’,数字的相反数入栈即可
  • 是 ‘*’,就可以进行计算了, 因为这里没有括号,所以乘和除的计算优先级最高,步骤:取出栈顶元素相乘,之后继续放到栈中
  • 是 ‘-’,取出栈顶元素除以数字,之后放到栈中
  1. 把栈中处理过的数字出栈进行相加

接下来的代码里还会再次进行强调的,看下面的图更容易理解:

在这里插入图片描述

2. 代码

看下面的代码对照着上面的流程解析可能会更加的清楚。

class Solution {// 练习public int calculate(String s1) {// 利用一个双端队列 deque, 先计算乘除. 或者是 栈 Stack 也是可以的Deque<Integer> stack = new ArrayDeque<>();int n = s1.length(), i = 0;char op = '+'; // 初始化为 + 号, 为了统一操作: 加入第一个数char[] s = s1.toCharArray();while(i < n) {// 1. 碰见空格, 忽略if(s[i] == ' ') i++;// 2. 碰见数字else if (s[i] >= '0' && s[i] <= '9') {// 提取出数字(有可能是两位或者三位数)int tmp = 0;while(i < n && s[i] >= '0' && s[i] <= '9') {tmp = tmp * 10 + s[i] - '0';i++;}// 提取之后, 判断当前数字前面的符号, 根据符号入栈if(op == '+') stack.push(tmp);else if(op == '-') stack.push(-tmp);else if(op == '*') {// stack.peek() * tmp; 泛型是 Integer, 不是引用类型, 所以不能用 peek, 指向的不是同一个地址// 8.25 更新: 感觉上面说的话不对应该,应该是忘记弹出了// 下一个题中的 泛型是 StringBuffer 就可以stack.push( stack.pop() * tmp );} // else stack.peek() / tmp;else stack.push( stack.pop() / tmp );// i 已经执行非数字了, 所以不用 i++ 了// 3. 碰见符号了, 直接更新符号即可     } else {op = s[i];i++;}}// 遍历完之后, 把栈里的元素进行相加int ret = 0;while(!stack.isEmpty()) {ret += stack.pop();}return ret;}
}

🎗️🎗️🎗️ 好啦,到这里有关本题的分享就没了,如果感觉做的还不错的话可以点个赞,关注一下,你的支持就是我继续下去的动力,我们下期再见,拜了个拜~ ☆*: .。. o(≧▽≦)o .。.:*☆

这篇关于【栈】| 力扣高频题: 基本计算器二的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121908

相关文章

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

用Java打造简易计算器的实现步骤

《用Java打造简易计算器的实现步骤》:本文主要介绍如何设计和实现一个简单的Java命令行计算器程序,该程序能够执行基本的数学运算(加、减、乘、除),文中通过代码介绍的非常详细,需要的朋友可以参考... 目录目标:一、项目概述与功能规划二、代码实现步骤三、测试与优化四、总结与收获总结目标:简单计算器,设计

基本知识点

1、c++的输入加上ios::sync_with_stdio(false);  等价于 c的输入,读取速度会加快(但是在字符串的题里面和容易出现问题) 2、lower_bound()和upper_bound() iterator lower_bound( const key_type &key ): 返回一个迭代器,指向键值>= key的第一个元素。 iterator upper_bou

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

C 语言的基本数据类型

C 语言的基本数据类型 注:本文面向 C 语言初学者,如果你是熟手,那就不用看了。 有人问我,char、short、int、long、float、double 等这些关键字到底是什么意思,如果说他们是数据类型的话,那么为啥有这么多数据类型呢? 如果写了一句: int a; 那么执行的时候在内存中会有什么变化呢? 橡皮泥大家都玩过吧,一般你买橡皮泥的时候,店家会赠送一些模板。 上

FreeRTOS-基本介绍和移植STM32

FreeRTOS-基本介绍和STM32移植 一、裸机开发和操作系统开发介绍二、任务调度和任务状态介绍2.1 任务调度2.1.1 抢占式调度2.1.2 时间片调度 2.2 任务状态 三、FreeRTOS源码和移植STM323.1 FreeRTOS源码3.2 FreeRTOS移植STM323.2.1 代码移植3.2.2 时钟中断配置 一、裸机开发和操作系统开发介绍 裸机:前后台系

Java 多线程的基本方式

Java 多线程的基本方式 基础实现两种方式: 通过实现Callable 接口方式(可得到返回值):