首页 > 其他 > 详细

广度优先遍历--合法的括号

时间:2019-10-11 22:11:39      阅读:146      评论:0      收藏:0      [点我收藏+]

问题描述:s="(a)(b)))",通过移除最少量的括号,使得该字符串为合法的字符串,即括号要配对。

首先我们要有一个判断该字符串是否是合法的函数:

def isvalid(s):
    count=0
    for i in s:
        #若是左括号,则count加1
        if i=="(":
            count+=1
        elif i==")":
            #如果是右括号,那么count减1,当count<0时,则直接返回不合法
            count-=1
            if count<0:
                return False
    return count==0    

然后,对于不合法的的字符串,我们进行遍历,然后遇到“(”或者")",我们就删除它,将删除后的字符串加入到队列中,以此类推;

def bfs(s):
    #保存结果
    res=[]
    #存储字符串
    queue=[s]
    #bfs
    while len(queue)>0:
        for i in range(len(queue)):
            if isvalid(queue[i]):
                res.append(queue[i])
        if len(res)>0:
            return list(set(res))
        tmp=[]
        for t in queue:
            for i in range(len(t)):
                if t[i]=="(" or t[i]==")":
                    tmp.append(t[:i]+t[i+1:])
        queue=list(set(tmp))
        #queue:[‘a)(b))()‘, ‘(a)b))()‘, ‘(a)(b))(‘, ‘(a(b))()‘, ‘(a)(b)()‘, ‘(a)(b)))‘]
    return list(set(res))
最后输出:[(a(b))(), (a)(b)()]

 

广度优先遍历--合法的括号

原文:https://www.cnblogs.com/xiximayou/p/11657066.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!