leetcode:单词搜索

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qfashly/article/details/79855640

给定一个二维面板和一个单词,找出该单词是否存在于网格中。
这个词可由顺序相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。

    public static boolean exist(char[][] board, String word) {
        char[] strs = word.toCharArray();
        int r = board.length;
        int c = board[0].length;
        for(int i = 0; i < r; i ++){
            for(int j = 0; j < c; j ++){
                //二维数组中匹配word中的第一个单词
                if(board[i][j] == strs[0] && wordsExist(board, 0, i, j, strs)){
                    return true;
                }
            }
        }
        return false;
    }

    public static boolean wordsExist(char[][] board, int index, int r, int c, char[] strs){
        //如果是word最后一个单词,则遍历完成,结束
        if(index == strs.length - 1){
            return true;
        }
        char str = strs[index + 1];//开始查找的单词
        char temp = board[r][c];//保存二维数组开始查找的位置的单词
        board[r][c] = ' ';//标志为找过的位置
        //上
        if(r - 1 >= 0 && board[r - 1][c] == str && wordsExist(board, index + 1, r - 1, c, strs)){
            return true;
        }
        //下
        if(r + 1 < board.length && board[r + 1][c] == str && wordsExist(board, index + 1, r + 1, c, strs)){
            return true;
        }
        //左
        if(c - 1 >= 0 && board[r][c - 1] == str && wordsExist(board, index + 1, r, c - 1, strs)){
            return true;
        }
        //右
        if(c + 1 < board[0].length && board[r][c + 1] == str && wordsExist(board, index + 1, r, c + 1, strs)){
            return true;
        }
        board[r][c] = temp;//还原原来的单词
        return false;
    }

猜你喜欢

转载自blog.csdn.net/qfashly/article/details/79855640
今日推荐