查看: 243|回复: 0
收起左侧

[字符串] 301. Remove Invalid Parentheses 这个代码是如何返回空列表的情况的???????

|只看干货
ATPtennis | 显示全部楼层 |阅读模式
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   47% (48)
 
 
52% (53)    👎

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
本帖最后由 ATPtennis 于 2021-11-29 22:15 编辑

class Solution:
    def removeInvalidParentheses(self, s: str) -> List[str]:

        # level = {"(a)())()"}
        level = {s}

        def isValid(s):

            count = 0            
            for c in s:

                if c == "(":
                    count += 1

                elif c == ")":
                    count -= 1

                    if count < 0:
                        return False

            return count == 0


        while True:

            valid = []

            for ele in level:

                if isValid(ele):                    
                    valid.append(ele)

            if valid:
                return valid

            new_level = set()

            # BFS
            for ele in level:
                for i in range(len(ele)):

                    new_level.add(ele[:i] + ele[i+1:])

            level = new_level

上面这个代码一般情况是没问题的,比如 s = "(a)())()",这样删除一个最后会返回valid列表。但是如果s = "((",这情况整个while True也不会停啊,然后valid一直是空的,只有valid不空时才返回东西。那么最后结果""空字符串是如何返回的?

知道问题在哪了。比如当s = { "(" }时,
for ele in level:
     for i in range(len(ele)):

          new_level.add(ele[:i] + ele[i+1:])

这几行代码运行完,new_level = {""},而不是{}。

也就是说,一个字符串a当我们写a[:0]时,它返回的是一个空字符串"",这样理解对吗?
比如a = "1",那么a[:0] = a[1:] = "".是这样吗?

评分

参与人数 1大米 +3 收起 理由
14417335 + 3 欢迎分享你知道的情况,会给更多积分奖励!

查看全部评分


上一篇:转码-概念题怎么刷
下一篇:苹果6个月力扣高频题
您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表