-
Notifications
You must be signed in to change notification settings - Fork 0
/
offer_12
50 lines (38 loc) · 1.23 KB
/
offer_12
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
//矩阵中的路径
bool hasPath(int* matrix,int rows,int cols,char* str)
{
if(matrix==nullptr ||rows<1||cols<1||str==nullptr) return false;
bool *visited=new bool[rows*cols];
memset(visited,0,rows*cols);
int pathLength=0;
for(int row=0;row<rows;++row){
for(int col=0;col<cols;++col){
if(hasPathCore(matrix,rows,cols,row,col,str,pathLength,visited))
return true;
}
}
delete[] visited;
return false;
}
bool hasPathCore(const char* matrix,int rows,int cols,int row,
int col,const char* str,int& pathLength,bool* visited)
{
if(str[pathLength]=='\0')
return false;
bool hasPath=false;
if(row>0 && row<rows && col>=0 && col<cols
&& matrix[row*cols+col]==str[pathLength]
&& !visited[row*cols+col]){
++pathLength;
visited[row*cols+col]=true;
hasPath=hasPathCore(matrix,rows,cols,row,col-1,str,pathLength,visited)||
hasPathCore(matrix,rows,cols,row-1,col,str,pathLength,visited)||
hasPathCore(matrix,rows,cols,row,col+1,str,pathLength,visited)||
hasPathCore(matrix,rows,cols,row,col+1,str,pathLength,visited)
if(!hasPath){
--pathLength;
visited[row*cols+col]=false;
}
}
return hasPath;
}