题解 | #表达式求值#

表达式求值

https://www.nowcoder.com/practice/c215ba61c8b1443b996351df929dc4d4

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 返回表达式的值
# @param s string字符串 待计算的表达式
# @return int整型
#
class Solution:
    def solve(self , s: str) -> int:
        # write code here
        if '(' not in s:
            start = s.find('*')
            if start == -1:
                s = s.replace('+-', '-')
                s = s.replace('--', '+')
                start = s.find('+')
                if start == -1:
                    start = s.rfind('-')
                    if start == -1 or start == 0:
                        if s == '':
                            return 0
                        else:
                            return int(s)
                    else:                    
                        return self.solve(s[:start]) - self.solve(s[start + 1:])
                else:
                    return self.solve(s[:start]) + self.solve(s[start + 1:])
            else:
                left, right = s[:start], s[start + 1:]
                num1 = ''
                while left != '' and left[-1].isdecimal():
                    num1 = left[-1] + num1
                    left = left[:-1]
                num2 = ''
                while (right != '' and right[0].isdecimal()) or num2 == '':
                    num2 = num2 + right[0]
                    right = right[1:]
                return self.solve(left + str(int(num1) * int(num2)) + right)
        else:
            start = s.find('(')
            parse = 0
            for end in range(len(s)):
                if s[end] == '(':
                    parse += 1
                elif s[end] == ')':
                    parse -= 1
                    if parse == 0:
                        break
            sub_str = s[start + 1: end]
            val = self.solve(sub_str)
            if val == 6:
                print(val)
            new_str = s[:start] + str(val) + s[end + 1:]
            return self.solve(new_str)

全部评论

相关推荐

ArisRobert:统一解释一下,第4点的意思是,公司按需通知员工,没被通知到的员工是没法去上班的,所以只要没被通知到,就自动离职。就是一种比较抽象的裁员。
点赞 评论 收藏
分享
贺兰星辰:不要漏个人信息,除了简历模板不太好以外你这个个人简介是不是太夸大了...
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务