面试热题(单词搜索)

给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false

单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中"相邻"单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。

这种是不是和岛屿搜索的类型题是相似的,每个点都有8个位置的选择,这种类型题就可以用我们上次讲的岛屿数量的解法,通过深度优先遍历(dfs)进行解决

java 复制代码
   //设置方向  上右下左
    int[] xnum={-1,0,1,0};
    int[] ynum={0,1,0,-1};

我们可以维护一个visited数组,防止走回头路

java 复制代码
 boolean[][] visited;

递归函数中入参的变量我们看需要哪些?原数组肯定是需要的,然后我们也需要知道我们已经遍历到哪个点了,因为我们要找的是字符串,我们也要知道当前遍历到字符串的哪个索引上,函数签名如下:

java 复制代码
  private boolean dfs(char[][] board, String word, int startIndex, int x, int y) {}

如果当前遍历到字符串索引的最后一位且网格中也有相同的字符,那就说明该路径我们在网格中是可以找到的,如果找不到,直接返回false,如果当前不是字符串的最后一个索引对应的位置,在从当前元素的相邻元素不断的去进行寻找,直到找到返回true或者fasle为止

源码如下:

java 复制代码
    //设置方向  上右下左
    int[] xnum={-1,0,1,0};
    int[] ynum={0,1,0,-1};
    boolean[][] visited;
    int row;
    int column;
    public boolean exist(char[][] board, String word) {
        //对入参进行判断
        if(board==null||board.length==0||board[0].length==0){
            return false;
        }
        //从每一个点都开始进行遍历
        row=board.length;
        column=board[0].length;
        visited=new boolean[row][column];
        for (int i = 0; i <row; i++) {
            for (int j = 0; j <column; j++) {
                //如果存在一种情况则返回true
                if(dfs(board,word,0,i,j)){
                    return true;
                }
            }
        }
        return false;
        }
    private boolean dfs(char[][] board, String word, int startIndex, int x, int y) {
          if(startIndex==word.length()-1){
            if(word.charAt(startIndex)==board[x][y]){
                return true;
            }
        }
        if(word.charAt(startIndex)!=board[x][y]){
            return false;
        }else{
            //向四个方向进行寻找
            visited[x][y]=true;
            for (int i = 0; i <4; i++) {
                int newx=x+xnum[i];
                int newy=y+ynum[i];
                //如果越界的话则不需要进行考虑
                if(newx<0||newx>=row||newy<0||newy>=column||visited[newx][newy]){
                    continue;
                }
                if(dfs(board,word,startIndex+1,newx,newy)){
                    return true;
                }        
            }
            //回溯
            visited[x][y]=false;
        }
        return false;
    }
相关推荐
wuminyu1 小时前
Java锁机制之park与futex系统级协同机制解析
java·linux·c语言·jvm·c++
疯狂打码的少年1 小时前
编译程序与解释程序的区别
java·开发语言·笔记
小雨下雨的雨5 小时前
井字棋AI机器人实现详解 - Minimax算法实战-鸿蒙PC Electron框架完成
前端·人工智能·算法·华为·electron·鸿蒙
xieliyu.8 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
明夜之约8 小时前
Spring Boot 自动装配源码
java·spring boot·后端
Leaton Lee8 小时前
Spring Boot分层架构详解:从Controller到Service再到Mapper的完整流程
java·spring boot·后端·架构
Jinkxs8 小时前
Resilience4j- 与 Spring Boot 快速集成:自动配置与基础注解使用
java·spring boot·后端
辣机小司8 小时前
【踩坑记录:Spring Boot 配置文件读取值不一致?警惕 YAML 的“八进制陷阱”与 SnakeYAML 版本之谜】
java·spring boot·后端·yaml·踩坑记录
一条小锦吕*8 小时前
基于Spring Boot + 数据可视化 + 协同过滤算法的推荐系统设计与实现(源码+论文+部署全讲解)
spring boot·算法·信息可视化
綝~9 小时前
爬虫数据采集工程师岗位面试题
爬虫·面试·请求