python-leetcode-1021. 删除最外层的括号

1021. 删除最外层的括号 - 力扣(LeetCode)

可以使用栈来实现这个任务。遍历字符串 s 时,使用一个计数器 balance 来跟踪当前的嵌套深度。当 balance 为 0 时,意味着一个新的原语开始。

以下是实现代码:

def remove_outer_parentheses(s: str) -> str:
    result = []
    balance = 0  # 记录当前的嵌套深度
    
    for char in s:
        if char == '(':
            if balance > 0:  # 只有在嵌套深度大于0时才加入
                result.append(char)
            balance += 1
        elif char == ')':
            balance -= 1
            if balance > 0:  # 只有在减少后的嵌套深度仍大于0时才加入
                result.append(char)
    
    return "".join(result)

# 示例测试
s = "(()())(())"
print(remove_outer_parentheses(s))  # 输出 "()()()"

这个算法的时间复杂度是 O(n),其中 n 是字符串 s 的长度。它通过一次遍历即可完成分解和删除外层括号的任务。你可以用不同的测试用例来验证它的正确性!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值