leetcode 241Different Ways to Add Parentheses 为运算表达式设计优先级 解题记录

本文介绍了一种算法,如何根据给定的数字和运算符字符串expression,计算所有可能的括号组合方式,以得到运算结果。通过递归和分治策略,解决表达式的计算问题,适用于满足32位整数范围且结果数量不多于104种的情况。
摘要由CSDN通过智能技术生成

241 Different Ways to Add Parentheses
Given a string expression of numbers and operators, return all possible results from computing all the different possible ways to group numbers and operators. You may return the answer in any order.

The test cases are generated such that the output values fit in a 32-bit integer and the number of different results does not exceed 104.

  1. 为运算表达式设计优先级
    给你一个由数字和运算符组成的字符串 expression ,按不同优先级组合数字和运算符,计算并返回所有可能组合的结果。你可以 按任意顺序 返回答案。

生成的测试用例满足其对应输出值符合 32 位整数范围,不同结果的数量不超过 104 。

经典分治题,核心就是一句话, 任何计算都是 a+b, a-b, a*b, a/b, 所以,分治就是左边一坨,右边一坨,然后左右的就丢给recursion来解决。

class Solution:
    def diffWaysToCompute(self, expression: str) -> List[int]:
        if expression.isdigit():
            return [int(expression)]
        res = []
        for i in range(len(expression)):
            if expression[i] in "+-*/":
                left = self.diffWaysToCompute(expression[:i])
                right = self.diffWaysToCompute(expression[i+1:])
                for j in left:
                    for k in right:
                        if expression[i] == "+":
                            res.append(j + k)
                        elif expression[i] == "-":
                            res.append(j - k)
                            
                        elif expression[i] == "*":
                            res.append(j * k)
        return res  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值