【栈】224. 基本计算器

2024-02-20 14:52
文章标签 基本 计算器 224

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

224. 基本计算器

解题思路

  • 首先将输入的字符串转换为字符队列。
  • 调用 helper() 方法,将字符队列作为参数进行计算。
  • 在 helper() 方法中,创建一个栈来存储中间计算结果,初始化符号为 ‘+’,初始化数字为 0。
  • 循环处理字符队列中的每个字符。
  • 如果当前字符是数字,则将其与之前的数字组合成完整的数字。
  • 如果遇到左括号,则开始递归计算括号内的表达式值。
  • 如果当前字符不是数字且不是空格,或者队列已经为空,则说明遇到了一个完整的数字和一个符号,根据之前记录的符号对数字进行相应的操作,并将结果入栈。
  • 如果遇到右括号,则结束当前递归并返回结果。
  • 最后,计算栈中所有元素的和作为最终结果,并返回。
class Solution {public int calculate(String s) {Queue<Character> queueS = new LinkedList<>();for(char c:s.toCharArray()){queueS.add(c);}return helper(queueS);}private int helper(Queue<Character> s){Stack<Integer> stack = new Stack<Integer>();// 存储中间结果char sign = '+';int num = 0;while(!s.isEmpty()){char c = s.poll();// 出队字符if(Character.isDigit(c)){// 如果是数字 num = num * 10 + Character.getNumericValue(c);}// 遇到左括号开始递归计算numif(c == '('){num = helper(s);}// 如果是运算符或者是空格  或者是字符栈为空if(!Character.isDigit(c) && c != ' ' || s.isEmpty()){if(sign == '+'){stack.push(num);}else if(sign == '-'){stack.push(-num);}else if(sign == '*'){stack.push(stack.pop() * num);// 取出栈顶元素 然后做乘法计算}else if(sign == '/'){stack.push(stack.pop() / num);}num = 0;sign = c;}// 遇到右括号返回递归结果if(c == ')'){break;}}int res = 0;for(int i : stack){res += i;// 计算最后结果}return res;}
}

这篇关于【栈】224. 基本计算器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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 接口方式(可得到返回值):