日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

python迷宫求解代码_Python中的迷宫求解

發(fā)布時間:2024/7/19 python 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python迷宫求解代码_Python中的迷宫求解 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

我孜孜不倦地試圖用python制作一個迷宮解算器。我已經(jīng)使用了我所有的資源,比如朋友、互聯(lián)網(wǎng)和堆棧。我已經(jīng)根據(jù)之前的堆棧問題修改了很多代碼,但是即使完全復(fù)制代碼(我不喜歡這樣做),也無法得到答案。在

迷宮/輸入文件(嵌套列表):[['*', '*', '*', '*', '*'],

['*', ' ', '*', ' ', '*'],

['*', ' ', ' ', ' ', '*'],

['*', ' ', '*', ' ', 'E'],

['*', 'S', '*', '*', '*']]

此函數(shù)在迷宮中的相同點上循環(huán)。我的起點“S”是(4,1),其輸出為:

^{pr2}$

上面的語句是用來打印調(diào)試函數(shù)I的。它只是按這個順序打印上面的內(nèi)容,直到它到達(dá)遞歸限制。低于是我的求解函數(shù):already_visited=[]

def solve(x,y):

global already_visited

matrix = draw(load())

print (x,y)

#base cases

if matrix[x][y] == "E":

for row in matrix:

row = str(row)[1:-1]

print row

return True

if matrix[x][y] == "*":

return False

if matrix[x][y] == "x":

return False

matrix[x][y] = "x"

#---------------------

if (x,y) in already_visited: #check if we have already been here

return False

already_visited.append((x,y)) #add position to list

#---------------------

# recursive cases (matrix traversal)

if (x < len(matrix)-1 and solve1(x+1,y)):

return True

elif (y > 0 and solve1(x,y-1)):

return True

elif (x > 0 and solve1(x-1,y)):

return True

elif (y < len(matrix)-1 and solve1(x,y+1)):

return True

else:

return False

我輸入的x和y的函數(shù)都是起始索引,如上面的迷宮所示。非常感謝任何幫助!在

總結(jié)

以上是生活随笔為你收集整理的python迷宫求解代码_Python中的迷宫求解的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。