LeetCode 212题 单词搜索II

LeetCode 212题
这个就硬递归了
在这里插入图片描述

class Solution {
    List<String> resList = new ArrayList<>();

    public List<String> findWords(char[][] board, String[] words) {
        int row = board.length;
        int column = board[0].length;
        int length = words.length;
		for(int i = 0; i < row; i++){
            for(int j = 0; j < column; j++){
                for(int k = 0; k < length; k++){
                    if(board[i][j] == words[k].charAt(0)){
                        if(words[k].length() == 1 && !resList.contains(words[k])) {
                            resList.add(words[k]);
                            continue;
                        }
                        if(words[k].length() > row * column) {
                            continue;
                        }
                        dfs(board, words[k], i, j, 1, -1);
                    }
                }
            }
        }		
		return resList;
    }

    private void dfs(char[][] board, String word, int row, int column, int index, int way){
        if(index == word.length()) {
            return;
        }
         if(way != 2 && column + 1 < board[0].length && board[row][column + 1] == word.charAt(index)){
             if(index == word.length() - 1 && !resList.contains(word)) {//往右
                 resList.add(word);
                 return;
             }
			 dfs(board, word, row, column+1, index+1, 1);
         }
         if(way != 1 && column - 1 >= 0 && board[row][column - 1] == word.charAt(index)) {
             if(index == word.length() - 1 && !resList.contains(word)) {//往左
                 resList.add(word);
                 return;
             }
             dfs(board, word, row, column-1, index+1, 2);
		 }
         if(way != 4 && row + 1 < board.length && board[row + 1][column] == word.charAt(index)) {
		 if(index == word.length() - 1 && !resList.contains(word)) {//往下
			 resList.add(word);
			 return;
		 }
			dfs(board, word, row+1, column, index+1, 3);
		 }
         if(way != 3 && row - 1 >= 0 && board[row - 1][column] == word.charAt(index)) {
             if(index == word.length() - 1 && !resList.contains(word)) {//往上
                 resList.add(word);
                 return;
             }
             dfs(board, word, row-1, column, index+1, 4);
         }
	}
}

纯递归做法
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值