鱼C论坛

 找回密码
 立即注册
查看: 1606|回复: 0

[技术交流] C++刷LeetCode(778. 水位上升的泳池中游泳)【深度优先搜索】【二分查找法】

[复制链接]
发表于 2021-1-30 15:36:43 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目描述:
在一个 N x N 的坐标方格 grid 中,每一个方格的值 grid[i][j] 表示在位置 (i,j) 的平台高度。

现在开始下雨了。当时间为 t 时,此时雨水导致水池中任意位置的水位为 t 。你可以从一个平台游向四周相邻的任意一个平台,但是前提是此时水位必须同时淹没这两个平台。假定你可以瞬间移动无限距离,也就是默认在方格内部游动是不耗时的。当然,在你游泳的时候你必须待在坐标方格里面。

你从坐标方格的左上平台 (0,0) 出发。最少耗时多久你才能到达坐标方格的右下平台 (N-1, N-1)?

 

示例 1:

输入: [[0,2],[1,3]]
输出: 3
解释:
时间为0时,你位于坐标方格的位置为 (0, 0)。
此时你不能游向任意方向,因为四个相邻方向平台的高度都大于当前时间为 0 时的水位。

等时间到达 3 时,你才可以游向平台 (1, 1). 因为此时的水位是 3,坐标方格中的平台没有比水位 3 更高的,所以你可以游向坐标方格中的任意位置
示例2:

输入: [[0,1,2,3,4],[24,23,22,21,5],[12,13,14,15,16],[11,17,18,19,20],[10,9,8,7,6]]
输出: 16
解释:
 0  1  2  3  4
24 23 22 21  5
12 13 14 15 16
11 17 18 19 20
10  9  8  7  6

最终的路线用加粗进行了标记。
我们必须等到时间为 16,此时才能保证平台 (0, 0) 和 (4, 4) 是连通的
 

提示:

2 <= N <= 50.
grid[i][j] 是 [0, ..., N*N - 1] 的排列。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/swim-in-rising-water
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


class Solution {
private:
    int len1, len2;
    vector<vector<int> >direct = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}};
public:
    bool dfs(vector<vector<int> >&grid, vector<vector<bool> >&visit, int x, int y, int res){
        if(x == len1 - 1 && y == len2 - 1){
            return true;
        }
        visit[x][y] = true;
        for(auto cha : direct){
            int temp1 = x + cha[0];
            int temp2 = y + cha[1];
            if(temp1 >= 0 && temp1 < len1 && temp2 >= 0 && temp2 < len2 && visit[temp1][temp2] == false && grid[temp1][temp2] < res && grid[x][y] < res){
                if(dfs(grid, visit, temp1, temp2, res))return true;//所有可能路径,不需要回溯
            }
        }
        return false;

    }
    int swimInWater(vector<vector<int>>& grid) {
        //二分查找+深度优先搜索
        len1 = grid.size(), len2 = grid[0].size();
        int left = 0, right = INT_MAX;
        while(left <= right){
            int mid = left + (right - left) / 2;
            vector<vector<bool> >visit(len1, vector<bool>(len2, false));
            if(!dfs(grid, visit, 0, 0, mid)){
                left = mid + 1;
            }else{
                right = mid - 1;
            }
        }
        return left-1;
    }
};


参考链接:https://leetcode-cn.com/problems ... 1-by-heroding-99vh/

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-12 01:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表