zoukankan      html  css  js  c++  java
  • 剑指offer系列39-----矩阵中的路径

    【题目】请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。
    * 路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子。
    * 如果一条路径经过了矩阵中的某一个格子,则该路径不能再进入该格子。
    * 例如 a b c e s f c s a d e e 矩阵中包含一条字符串”bcced”的路径,但是矩阵中不包含”abcb”路径,
    * 因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再次进入该格子。

     1 package com.exe8.offer;
     2 
     3 /**
     4  * 【题目】请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。
     5  *            路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子。
     6  *        如果一条路径经过了矩阵中的某一个格子,则该路径不能再进入该格子。 
     7  *           例如 a b c e s f c s a d e e 矩阵中包含一条字符串”bcced”的路径,但是矩阵中不包含”abcb”路径,
     8  *                因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再次进入该格子。
     9  * @author rhwayfun
    10  *
    11  */
    12 public class HasPath {
    13 
    14    public boolean hasPath(char[] matrix,int rows,int cols,char[] str){
    15        boolean[] visited=new boolean[matrix.length];
    16        for(int i=0;i<rows;i++){
    17            for(int j=0;j<cols;j++){
    18                if(hasPathCore(matrix,rows,cols,i,j,0,str,visited)){
    19                    return true;
    20                }
    21            }
    22        }
    23        return false;
    24        
    25    }
    26    //k表示在str字符串中数的位置
    27     private boolean hasPathCore(char[] matrix, int rows, int cols, 
    28                                 int i, int j, int k, char[] str, boolean[] visited) {
    29         //获取指定数在矩阵中的下标
    30         int index=i*cols+j;
    31         if(i<0 || i>=rows ||j<0 || j>=cols
    32            ||matrix[index]!=str[k] ||visited[index])
    33             return false;
    34         visited[index]=true;
    35         if(k==str.length-1)//表面要找的字符全部找到
    36             return true;
    37         //如果没有递归到最后一个字符  就k+1依次寻找str下个字符
    38         if(hasPathCore(matrix, rows, cols, i-1, j, k+1, str, visited)
    39          ||hasPathCore(matrix, rows, cols, i+1, j, k+1, str, visited)
    40          ||hasPathCore(matrix, rows, cols, i, j-1, k+1, str, visited)
    41          ||hasPathCore(matrix, rows, cols, i, j+1, k+1, str, visited)){
    42             return true;
    43         }else{
    44             k--;
    45             visited[index]=false;
    46         }
    47         
    48         
    49         return false;
    50     }
    51     public static void main(String[] args) {
    52         String s= "abcesfcsadee";
    53         String s2 = "bcced";
    54         char[] matrix = s.toCharArray();
    55         char[] str = s2.toCharArray();
    56         boolean b = new HasPath().hasPath(matrix, 3, 4, str);
    57         System.out.println(b);
    58     }
    59 }
  • 相关阅读:
    tcp 粘包 和 TCP_NODELAY 学习
    分解抓取的包文件代码实现学习
    谨慎使用多线程中的fork 学习!!!!
    面试题
    Java并发编程:Lock
    为什么匿名内部类参数必须为final类型
    sql 面试题
    java hashCode方法返回值
    数组初始化
    Java内存模型
  • 原文地址:https://www.cnblogs.com/noaman/p/5597869.html
Copyright © 2011-2022 走看看