题干
给定一个二维网格和一个单词,找出该单词是否存在于网格中。
单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。
示例:
board =
[
[‘A’,‘B’,‘C’,‘E’],
[‘S’,‘F’,‘C’,‘S’],
[‘A’,‘D’,‘E’,‘E’]
]
给定 word = “ABCCED”, 返回 true.
给定 word = “SEE”, 返回 true.
给定 word = “ABCB”, 返回 false.
想法
这道题真的是脑残题,看了半天才看懂为什么给定 word = “ABCCED”, 返回 true.。
flag来标记是否被访问,回溯
Java 代码
class Solution {
public boolean exist(char[][] board, String word) {
int cl=board.length;
int rl=board[0].length;
boolean[][]flag=new boolean[cl][rl];
for(int i=0;i<cl;i++){
for(int j=0;j<rl;j++){
if (find(board,word,flag,i,j,0))
return true;
}
}
return false;}
public boolean find(char[][] board,String word,boolean[][]flag,int i,int j,int index){
int cl=board.length;
int rl=board[0].length;
if(word.length()==index)//每个字符都被判断了
return true;
if(i<0||i>=cl||j>=rl||j<0)//越界
return false;
if(flag[i][j]||word.charAt(index)!=board[i][j])//被访问过或者不匹配
return false;
flag[i][j]=true;//访问了
boolean judge=find(board,word,flag,i-1,j,index+1)||find(board,word,flag,i+1,j,index+1)||find(board,word,flag,i,j-1,index+1)||find(board,word,flag,i,j+1,index+1);//上下左右再查找
flag[i][j]=false; // 重载字符访问状态
return judge;
}
}
一道sb题没有写的欲望