leetcode921. 使括号有效的最少添加

该代码实现了一个函数,计算使括号字符串有效所需的最小左括号添加数量。遍历字符串,计数左括号和右括号,当右括号多于左括号时,需要插入左括号。最后返回需添加的左括号总数加上剩余的右括号数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    #因为有顺序左括号在前,所以先统计左括号,有多少左括号对应需要多少右括号
    #遇到右括号可以减少需要的右括号,如果需要得右括号小于0,必须在前面插入左括号
def minAddToMakeValid(self, s):
        """
        :type s: str
        :rtype: int
        """
        need = 0   #记录需要多少个右括号
        res = 0    #记录需要多少个左括号
        for i in s:     
            if i == "(":
                need += 1
            if i == ")":
                need -= 1
                if need < 0:      #右大于左得时候需要插入左括号
                    res += 1
                    need = 0      #重置
        return res + need
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值