八数码问题 python实现 DFS深度优先搜索

这篇博客探讨了DFS和BFS在解决棋盘问题时的实现和区别。作者指出,Python中DFS和BFS的代码相似,主要区别在于数据结构的使用。DFS利用栈实现,可能无限深入搜索,而BFS则使用队列。为了优化DFS,作者限制了路径长度超过100的搜索,并通过set快速检索避免重复棋盘状态,最终在搜索效率上得到了提升。
摘要由CSDN通过智能技术生成

DFS跟BFS的代码几乎一致,尤其是在使用python实现的时候

def DFS():
    deq = []
    appear = set()#使用set进行检索极快,hash检索
    temp = board()
    appear.add(list2str(temp.groud))
    for x in temp.can_move():
        b = board()
        b.move_one(x)
        b.route.append(x)
        appear.add(list2str(b.groud))
        deq.append(b)
    flag = 0
    while True:
        flag+=1
        temp = deq.pop()
        if flag%10000==0:
            flag=0
            temp.show_board() 
            temp.show_route()

        if  temp.guiwei():
            temp.show_board() 
            temp.show_route()
            break
        for x in temp.can_move():
            # 筛选掉重复的棋盘情况,加快搜索速度
            if list2str(temp.test(x)) not in appear and len(temp.route)<=99:
                new_temp=copy.deepcopy(temp)
                new_temp.move_one(x)
                new_temp.route.append(x)
                deq.append(new_temp)
                appear.add(list2str(new_temp.groud))   

区别于BFS

  • 使用栈作为数据结构,先进后出.在代码上的体现很简单,把pop(0)改成pop()就好
  • 如果不限制的话,深度优先搜索会无限制的一直往下搜索,路径在到达终点前只会越来越长.所以我限制了超过100的路径直接放弃搜索
    在这里插入图片描述
    运气比较好,深度搜索的方向比较贴合方向,很快就搜索出来了.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

rglkt

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值