递归、搜索与回溯-综合练习:28.不同路径Ⅲ

题目链接:980. 不同路径 III(困难)

算法原理:

解法:DFS

Java代码:

java 复制代码
/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: 王洋
 * Date: 2025-10-09
 * Time: 12:36
 */
class Solution {
    //自己写的,注释处是找的错误:到2就返回+绕过障碍-1
    boolean[][] check;
    int m,n;
    int[] dx=new int[]{0,0,1,-1};
    int[] dy=new int[]{1,-1,0,0};
    int ret,step;
    public int uniquePathsIII(int[][] grid) {
        m=grid.length;n=grid[0].length;
        check=new boolean[m][n];
        //统计一共需要走的步数
        for(int[] tmp:grid){
            for(int x:tmp)
                if(x==0) step++;
        }
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                if(grid[i][j]==1){
                    check[i][j]=true;
                    dfs(grid,i,j,0);
                    check[i][j]=false;
                }
            }
        }
        return ret;
    }
    public void dfs(int[][] grid,int i,int j,int path){
        if(grid[i][j]==2){
            if(path==step+1) ret++;
            return;//无论是否合法,到终点都要返回
        }
        for(int k=0;k<4;k++){
            int x=i+dx[k],y=j+dy[k];
            //要绕过障碍-1
            if(x<m&&y<n&&x>=0&&y>=0&&!check[x][y]&&grid[x][y]!=-1){
                check[x][y]=true;
                dfs(grid,x,y,path+1);
                check[x][y]=false;
            }
        }
    }
    //吴小哲的解法:开始统计step的时候顺便标记起点,后面就不用两层for循环了
    boolean[][] check;
    int m,n;
    int[] dx=new int[]{0,0,1,-1};
    int[] dy=new int[]{1,-1,0,0};
    int ret,step;
    public int uniquePathsIII(int[][] grid) {
        m=grid.length;n=grid[0].length;
        check=new boolean[m][n];
        //统计一共需要走的步数
        int bx=0,by=0;
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                if(grid[i][j]==0) step++;
                    //标记起始位置
                else if(grid[i][j]==1){bx=i;by=j;}
            }
        }
        step+=2;//起点和终点的
        check[bx][by]=true;
        dfs(grid,bx,by,1);
        // for(int i=0;i<m;i++){
        //     for(int j=0;j<n;j++){
        //         if(grid[i][j]==1){
        //             check[i][j]=true;
        //             dfs(grid,i,j,0);
        //             check[i][j]=false;
        //         }
        //     }
        // }
        return ret;
    }
    public void dfs(int[][] grid,int i,int j,int path){
        if(grid[i][j]==2){
            if(path==step) ret++;
            return;//无论是否合法,到终点都要返回
        }
        for(int k=0;k<4;k++){
            int x=i+dx[k],y=j+dy[k];
            //要绕过障碍-1
            if(x<m&&y<n&&x>=0&&y>=0&&!check[x][y]&&grid[x][y]!=-1){
                check[x][y]=true;
                dfs(grid,x,y,path+1);
                check[x][y]=false;
            }
        }
    }
}
相关推荐
亦暖筑序3 分钟前
Java 8老系统AI工具接入:API包装成受控工具,只读优先+权限拦截
java·人工智能·aigc·企业架构·mcp协议
砍材农夫4 分钟前
物联网实战:Spring Boot + Netty 搭建 MQTT 统一接入层
java·网络·spring boot·后端·物联网·spring
写代码的小阿帆5 分钟前
英语四六级证书审核(SpringBoot+Dify+RPA)
java·spring boot
Samson Bruce5 分钟前
【初高中数学】
线性代数·数学·算法·机器学习
redaijufeng6 分钟前
我在C++中深入理解了继承,收获颇丰
java·c++·算法
承渊政道6 分钟前
【MySQL数据库学习】MySQL基本查询(下)
数据库·学习·mysql·leetcode·bash·数据库开发·数据库系统
Ricky05537 分钟前
DEIM :采用改进匹配算法实现快速收敛的DETR(中国25年3月研究)
人工智能·算法·目标跟踪
无限码力8 分钟前
美团研发岗 5月9号笔试真题 - 弹性分桶
算法·美团笔试题·美团研发岗笔试题·美团0509笔试题
J2虾虾9 分钟前
C 语言 sizeof 完全用法指南
c语言·数据结构·算法
就叫_这个吧13 分钟前
HTML或JSP页面链接CSS,link标签没问题,但不显示样式问题解决
java·前端·css·html·intellij-idea·jsp