每天一道leetcode:1306. 跳跃游戏 III(图论&中等&广度优先遍历)

今日份题目:

这里有一个非负整数数组 `arr`,你最开始位于该数组的起始下标 `start` 处。当你位于下标 `i` 处时,你可以跳到 `i + arr[i]` 或者 `i - arr[i]`。

请你判断自己是否能够跳到对应元素值为 0 的 **任一** 下标处。

注意,不管是什么情况下,你都无法跳到数组之外。

示例1

```

输入:arr = [4,2,3,0,3,1,2], start = 5

输出:true

解释:

到达值为 0 的下标 3 有以下可能方案:

下标 5 -> 下标 4 -> 下标 1 -> 下标 3

下标 5 -> 下标 6 -> 下标 4 -> 下标 1 -> 下标 3

```

示例2

```

输入:arr = [4,2,3,0,3,1,2], start = 0

输出:true

解释:

到达值为 0 的下标 3 有以下可能方案:

下标 0 -> 下标 4 -> 下标 1 -> 下标 3

```

示例3

```

输入:arr = [3,0,2,1,2], start = 2

输出:false

解释:无法到达值为 0 的下标 1 处。

```

提示

  • `1 <= arr.length <= 5 * 10^4`

  • `0 <= arr[i] < arr.length`

  • `0 <= start < arr.length`

题目思路

转移规则就是下一个位置可以跳到 i+arr[i] 或 i-arr[i] ,我们考虑搜索图中信息看搜索过程中能否途径存放着0的位置。我们使用bfs广度优先遍历,每次从队列中取出一个位置,然后根据转移规则判断,将不是存放着0的位置信息放入队列当中,直到队列为空。如果到过放着0的位置就返回true,否则就返回false。

代码

cpp 复制代码
class Solution 
{
public:
    bool canReach(vector<int>& arr, int start) 
    {
        if (arr[start]==0) return true;
        
        int n=arr.size();
        bool visited[100000]={false}; //用于标记到达过
        queue<int> p;
        p.push(start);
        visited[start]=true;
        //bfs
        while(!p.empty()) 
        {
            int cur=p.front();
            p.pop();
            //i+arr[i]的情况
            if(cur+arr[cur]>=0&&cur+arr[cur]<n&&visited[cur+arr[cur]]==false) 
            {
                if(arr[cur+arr[cur]]==0) return true; //到达终点,返回true
                //否则还未到终点,继续压入队列进行bfs
                p.push(cur+arr[cur]);
                visited[cur+arr[cur]]=true;
            }
            //i-arr[i]的情况
            if(cur-arr[cur]>=0&&cur-arr[cur]<n&&!visited[cur-arr[cur]]) 
            {
                if(arr[cur-arr[cur]]==0) return true; //到达终点,返回true
                //还未到终点,继续bfs
                p.push(cur-arr[cur]);
                visited[cur-arr[cur]]=true;
            }
        }
        //bfs遍历完还没到达终点,返回false
        return false;
    }
};

提交结果

欢迎大家在评论区讨论,如有不懂的部分,欢迎在评论区留言!

更新不易,宝子们点个赞支持下,谢谢!

每天一道leetcode,大家一起在评论区打卡呀!

相关推荐
唐梓航-求职中4 分钟前
编程大师-技术-算法-leetcode-1472. 设计浏览器历史记录
算法·leetcode
MSTcheng.5 分钟前
【C++】C++智能指针
开发语言·c++·智能指针
_OP_CHEN7 分钟前
【算法基础篇】(五十八)线性代数之高斯消元法从原理到实战:手撕模板 + 洛谷真题全解
线性代数·算法·蓝桥杯·c/c++·线性方程组·acm/icpc·高斯消元法
云深处@9 分钟前
【C++11】部分特性
开发语言·c++
YGGP13 分钟前
【Golang】LeetCode 1. 两数之和
leetcode
独望漫天星辰14 分钟前
C++ 树结构进阶:从工程化实现到 STL 底层与性能优化
开发语言·c++
唐梓航-求职中15 分钟前
编程大师-技术-算法-leetcode-355. 设计推特
算法·leetcode·面试
HellowAmy18 分钟前
我的C++规范 - 鸡蛋工厂
开发语言·c++·代码规范
少许极端21 分钟前
算法奇妙屋(二十八)-递归、回溯与剪枝的综合问题 1
java·算法·深度优先·剪枝·回溯·递归
仰泳的熊猫23 分钟前
题目1453:蓝桥杯历届试题-翻硬币
数据结构·c++·算法·蓝桥杯