• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
村雨sup
自己选的路,跪着也要走完 XD
博客园    首页    新随笔    联系   管理    订阅  订阅
Leetcode 980. 不同路径 III

980. 不同路径 III

 
我的提交返回竞赛
 
  • 用户通过次数42
  • 用户尝试次数43
  • 通过次数46
  • 提交次数60
  • 题目难度Hard

在二维网格 grid 上,有 4 种类型的方格:

  • 1 表示起始方格。且只有一个起始方格。
  • 2 表示结束方格,且只有一个结束方格。
  • 0 表示我们可以走过的空方格。
  • -1 表示我们无法跨越的障碍。

返回在四个方向(上、下、左、右)上行走时,从起始方格到结束方格的不同路径的数目,每一个无障碍方格都要通过一次。

 

示例 1:

输入:[[1,0,0,0],[0,0,0,0],[0,0,2,-1]]
输出:2
解释:我们有以下两条路径:
1. (0,0),(0,1),(0,2),(0,3),(1,3),(1,2),(1,1),(1,0),(2,0),(2,1),(2,2)
2. (0,0),(1,0),(2,0),(2,1),(1,1),(0,1),(0,2),(0,3),(1,3),(1,2),(2,2)

示例 2:

输入:[[1,0,0,0],[0,0,0,0],[0,0,0,2]]
输出:4
解释:我们有以下四条路径: 
1. (0,0),(0,1),(0,2),(0,3),(1,3),(1,2),(1,1),(1,0),(2,0),(2,1),(2,2),(2,3)
2. (0,0),(0,1),(1,1),(1,0),(2,0),(2,1),(2,2),(1,2),(0,2),(0,3),(1,3),(2,3)
3. (0,0),(1,0),(2,0),(2,1),(2,2),(1,2),(1,1),(0,1),(0,2),(0,3),(1,3),(2,3)
4. (0,0),(1,0),(2,0),(2,1),(1,1),(0,1),(0,2),(0,3),(1,3),(1,2),(2,2),(2,3)

示例 3:

输入:[[0,1],[2,0]]
输出:0
解释:
没有一条路能完全穿过每一个空的方格一次。
请注意,起始和结束方格可以位于网格中的任意位置。

 

提示:

  1. 1 <= grid.length * grid[0].length <= 20   
class Solution {
public:
    int uniquePathsIII(vector<vector<int>>& grid) {
        int n = grid.size();
        int m = grid[0].size();
        int a = 0;
        int b = 0;
        vector<vector<int>> vis(n,vector<int>(m));
        int cnt = 0;
        for(int i=0;i < n;i++){
            for(int j=0;j < m;j++){
                if(grid[i][j] == 0){
                    cnt++;
                    vis[i][j] = 0;
                }
                else if(grid[i][j] == 2){
                    vis[i][j] = 0;
                }
                else if(grid[i][j] == -1){
                    vis[i][j] = 1;
                }
                else if(grid[i][j] == 1){
                    vis[i][j] = 1;
                    a = i;b = j;
                }
            }
        }
        int res = 0;
        dfs(grid,vis,a,b,res,0,cnt);
        return res;
        
    }
    void dfs(vector<vector<int>> grid,vector<vector<int>> vis,int n,int m,int& num,int cnt,int maxnum){
        if(grid[n][m] == 2){
            if(cnt-1 == maxnum) num++;
            else return;
        }
        if((n-1>=0&&n-1<grid.size())&&(m>=0&&m<grid[0].size())&&vis[n-1][m] == 0){
            vis[n-1][m] = 1;
            dfs(grid,vis,n-1,m,num,cnt+1,maxnum);
            vis[n-1][m] = 0;
        }
        if((n+1>=0&&n+1<grid.size())&&(m>=0&&m<grid[0].size())&&vis[n+1][m] == 0){
            vis[n+1][m] = 1;
            dfs(grid,vis,n+1,m,num,cnt+1,maxnum);
            vis[n+1][m] = 0;
        }
        if((n>=0&&n<grid.size())&&(m+1>=0&&m+1<grid[0].size())&&vis[n][m+1] == 0){
            vis[n][m+1] = 1;
            dfs(grid,vis,n,m+1,num,cnt+1,maxnum);
            vis[n][m+1] = 0;
        }
        if((n>=0&&n<grid.size())&&(m-1>=0&&m-1<grid[0].size())&&vis[n][m-1] == 0){
            vis[n][m-1] = 1;
            dfs(grid,vis,n,m-1,num,cnt+1,maxnum);
            vis[n][m-1] = 0;
        }
    }
};

牛逼哦AC了

posted on 2019-03-23 02:40  村雨sup  阅读(345)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3