這個題目用的是回溯法。
之前回溯法練得比較少,所以這個題還是需要重視。
回溯法是演算法裡學過的,就是從第乙個可能得路徑開始找,一直找到最後乙個。
這個題目要注意一下幾點:
1.從第乙個開始找,如果第乙個元素等於要尋找的字串的第乙個元素,就繼續去尋找該元素的上下左右,看是否等於其下乙個。一直匹配到最後乙個元素。
3.因為訪問過得路徑不能再次訪問,因此要建立乙個同樣大小的bool型的變數記錄該當前位置是否已經走過。
1class
solution
18delete
visited;
19return
false;20
}21bool haspathcore(char* matrix, int rows, int cols, int row,int col,char* str,int index,bool *visit)
2241}42
43return
has;44}
4546
47 };
劍指Offer系列12 矩陣中的路徑
請設計乙個函式,用來判斷在乙個矩陣中是否存在一條包含某字串所有字元的路徑。路徑可以從矩陣中的任意一格開始,每一步可以在矩陣中向左 右 上 下移動一格。如果一條路徑經過了矩陣的某一格,那麼該路徑不能再次進入該格仔。例如,在下面的3 4的矩陣中包含一條字串 bfce 的路徑 路徑中的字母用加粗標出 a ...
劍指offer 矩陣中的路徑
請設計乙個函式,用來判斷在乙個矩陣中是否存在一條包含某字串所有字元的路徑。路徑可以從矩陣中的任意乙個格仔開始,每一步可以在矩陣中向左,向右,向上,向下移動乙個格仔。如果一條路徑經過了矩陣中的某乙個格仔,則該路徑不能再進入該格仔。例如 a b t g c f c s j d e h 矩陣中包含一條字串...
劍指offer 矩陣中的路徑
請設計乙個函式,用來判斷在乙個矩陣中是否存在一條包含某字串所有字元的路徑。路徑可以從矩陣中的任意乙個格仔開始,每一步可以在矩陣中向左,向右,向上,向下移動乙個格仔。如果一條路徑經過了矩陣中的某乙個格仔,則之後不能再次進入這個格仔。注意 樣例matrix a b c e s f c s a d e e...