【LeetCode】45.跳跃游戏II

题目链接:

45.跳跃游戏

题目描述:

思路一(广度优先搜索算法BFS)

通过广度优先搜索算法寻找最短距离

代码实现:

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int n = nums.size();
        if(n<=1) return 0;

        vector<int> visited(n,0);
        queue<pair<int, int>> qu;
        qu.push({0,0});
        visited[0] = 1;
        int ans = 0;

        while(!qu.empty()){
            pair<int, int> cur = qu.front();
            qu.pop();
            int index = cur.first;
            int step = cur.second;

            for(int k = nums[index]; k>0; k--){
                // 跳跃k步
                if((k+index) >= n-1){
                    ans = step+1;
                    break;
                }else{
                    if(visited[k+index] != 1){
                        qu.push({k+index, step+1});
                        visited[k+index] = 1;
                    }
                }
            }
            if(ans!=0){
                break;
            }
        }

        return ans;
    }
};

思路二(贪心算法)

例如,对于数组 [ 2 , 3 , 1 , 2 , 4 , 2 , 3 ] [2,3,1,2,4,2,3] [2,3,1,2,4,2,3], 初始位置是下标 0,从下标 0 出发,最远可到达下标 2。下标 0 可到达的位置中,下标 1 的值是 3,从下标 1 出发可以达到更远的位置,因此第一步到达下标 1。从下标 1 出发,最远可到达下标 4。下标 1 可到达的位置中,下标 4 的值是 4 ,从下标 4 出发可以达到更远的位置,因此第二步到达下标 4。

代码实现:

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int maxPos = 0;
        int n = nums.size();
        int end = 0;
        int step = 0;

        for(int i=0; i<n-1; i++){
            if (maxPos >= i){
                maxPos = max(maxPos, i+nums[i]);

                if(i==end){
                    end = maxPos;
                    step++;
                }
            }
        }
        return step;
    }
};
相关推荐
艾莉丝努力练剑28 分钟前
【LeetCode&数据结构】单链表的应用——反转链表问题、链表的中间节点问题详解
c语言·开发语言·数据结构·学习·算法·leetcode·链表
_殊途2 小时前
《Java HashMap底层原理全解析(源码+性能+面试)》
java·数据结构·算法
还债大湿兄2 小时前
《C++内存泄漏8大战场:Qt/MFC实战详解 + 面试高频陷阱破解》
c++·qt·mfc
珊瑚里的鱼5 小时前
LeetCode 692题解 | 前K个高频单词
开发语言·c++·算法·leetcode·职场和发展·学习方法
AI+程序员在路上5 小时前
QTextCodec的功能及其在Qt5及Qt6中的演变
开发语言·c++·qt
Risehuxyc6 小时前
C++卸载了会影响电脑正常使用吗?解析C++运行库的作用与卸载后果
开发语言·c++
秋说6 小时前
【PTA数据结构 | C语言版】顺序队列的3个操作
c语言·数据结构·算法
凯基迪科技7 小时前
游戏设备软件加密锁复制:技术壁垒与安全博弈
安全·游戏
lifallen7 小时前
Kafka 时间轮深度解析:如何O(1)处理定时任务
java·数据结构·分布式·后端·算法·kafka
liupenglove7 小时前
自动驾驶数据仓库:时间片合并算法。
大数据·数据仓库·算法·elasticsearch·自动驾驶