欢乐力扣:基本计算器

文章目录


1、题目描述

基本计算器

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

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

2、思路

本人也不太会,看的这个人的讲解视频:bibili.

代码

python 复制代码
class Solution:
    def calculate(self, s: str) -> int:
        ret = 0  # 记录结果
        num = 0  # 记录当前数字
        sign = 1 # 记录当前符号
        for char in s:
            # 如果碰到数字:比如134,则不断更新num的数值
            if char<= '9' and char >= '0': 
                num = num*10 + int(char)     
            # 如果碰到加号或者减号,则更新一遍ret,同时将符号位和num重置;
            elif char == '+':
                ret = ret + num*sign 
                sign = 1 
                num = 0
            elif char == '-':
                ret = ret + num*sign 
                sign = -1
                num = 0 
        return ret+num*sign  

括号

若包含括号,则需要用到栈:

python 复制代码
class Solution:
    def calculate(self, s: str) -> int:
        ret = 0  # 记录结果
        num = 0  # 记录当前数字
        sign = 1 # 记录当前符号
        stack = []  # 记录括号
        for char in s:
            # 如果碰到数字:比如134,则不断更新num的数值
            if char<= '9' and char >= '0': 
                num = num*10 + int(char)  
            # 如果碰到加号或者减号,则更新一遍ret,同时将符号位和num重置;
            elif char == '+':
                ret = ret + num*sign 
                sign = 1 
                num = 0
            elif char == '-':
                ret = ret + num*sign 
                sign = -1
                num = 0 
            # 若碰到左括号,则入栈res和当前符号:
            elif char == '(':
                stack.append(ret)
                stack.append(sign)
                num = 0
                sign = 1 
                ret = 0      # 千万记得这里吧ret也需要置为0,否则就累加了。
            elif char == ')':
                ret = ret + num*sign
                num  = 0 
                sign = 1
                # 更新ret的符号位
                ret *= stack[-1]
                stack.pop()
                # 更新ret的值
                ret += stack[-1]
                stack.pop()
        return ret+num*sign   # 返回最终的值
相关推荐
code_pgf21 小时前
Qwen2.5-VL 算法解析
人工智能·深度学习·算法·transformer
Code-keys1 天前
Android Codec2 Filter 算法模块开发指南
android·算法·音视频·视频编解码
无忧智库1 天前
低空经济新基建:构建低空飞行大数据中心与行业应用算法工厂的全景式蓝图(WORD)
算法
闻缺陷则喜何志丹1 天前
【背包 组合】P7552 [COCI 2020/2021 #6] Anagramistica|普及+
c++·算法·背包·洛谷·组合
一只机电自动化菜鸟1 天前
一建机电备考笔记(17) 常用设备—通用设备1(含考频+题型)
笔记·学习·职场和发展·生活·学习方法
小章UPUP1 天前
2026年第十六届MathorCup数学应用挑战赛D题国奖思路
算法
hssfscv1 天前
软件设计师下午试题四——C语言(N皇后问题、分治、动态规划)
c语言·算法·动态规划
lolo大魔王1 天前
Go语言的反射机制
开发语言·后端·算法·golang
白羊by1 天前
Softmax 激活函数详解:从数学原理到应用场景
网络·人工智能·深度学习·算法·损失函数
故事和你911 天前
洛谷-算法1-7-搜索3
数据结构·c++·算法·leetcode·动态规划