矩陣中的路徑

2021-09-24 02:51:24 字數 1087 閱讀 5586

思路:

矩陣如下:

abce

sfcs

adee

找到一條路徑,從矩陣任意頂點出發,設計乙個矩陣,記錄走過的路線為true,下次不能走。每次走的時候匹配路徑元素。

若上下左右每個方向都試一遍。每個方向都沒有結果,返回上一級,重置頂點為false。採用遞迴。

def haspath(self, matrix, rows, cols, path):

# write code here

assined=[false]*rows*cols

for i in range(rows):

for j in range(cols):

if self.haspath(matrix, rows, cols, path, i, j, assined):

return true

return false

def haspath(self,matrix, rows, cols, path, i,j, assined):

if not path :

return true

flag=i*cols+j

if i<0 or i>=rows or j<0 or j>=cols or matrix[flag]!=path[0] or assined[flag]==true:

return false

assined[flag]=true

if (self.haspath(matrix, rows, cols, path[1:], i-1,j, assined) or

self.haspath(matrix, rows, cols, path[1:], i+1,j, assined) or

self.haspath(matrix, rows, cols, path[1:], i,j+1, assined)or

self.haspath(matrix, rows, cols, path[1:], i,j-1, assined)):

return true

assined[flag]=false

return false

矩陣中的路徑

請設計乙個函式,用來判斷在乙個矩陣中是否存在一條包含某字串所有字元的路徑。路徑可以從矩陣中的任意乙個格仔開始,每一步可以在矩陣中向左,向右,向上,向下移動乙個格仔。如果一條路徑經過了矩陣中的某乙個格仔,則該路徑不能再進入該格仔。例如 3 4 矩陣 a b c e s f c s a d e e 中包...

矩陣中的路徑

題目描述 請設計乙個函式,用來判斷在乙個矩陣中是否存在一條包含某字串所有字元的路徑。路徑可以從矩陣中的任意乙個格仔開始,每一步可以在矩陣中向左,向右,向上,向下移動乙個格仔。如果一條路徑經過了矩陣中的某乙個格仔,則之後不能再次進入這個格仔。注意 輸入的路徑不為空 所有出現的字元均為大寫英文本母 樣例...

矩陣中的路徑

acwing打卡活動 劍指offer 打卡活動 周一第十一題 矩陣中的路徑 class solution 標記所有格仔的狀態,判斷機械人是否走過 boolean visited new boolean matrix.length matrix 0 length 置陣列所有元素為false visit...