力扣热题100道之45跳跃游戏2

解法

题解中的贪心算法

每次都更新可以到达终点的点。更新一次,次数加一

题目中保证了可以到n-1,所以我们每次只需要找到离终点最远的点,也就是索引最小的点。

直到索引为0的点,也可以到达最后的点。返回次数。

复制代码
class Solution {
    public int jump(int[] nums) {
        int n=nums.length;
        int count=0;
        int poi=n-1;
        while(poi>0){
            for(int i=0;i<n;i++){
                if(i+nums[i]>=poi){
                    poi=i;
                    break;
                }
            }
            count++;
        }
        return count;


    }
}
自己写的使用队列的解法

倒着找。每次都将可以到达n-1位置的点加入到队列中去。第一次直接将n-1加入到队列中,后面当i+nums[i]>=队列的头的时候,将i加入到辅助队列(因为边加边取,就会无法区分是上一次的还是这一次的)中,当i打大于队列的头的时候,将队列的头出队。这样就可以精确地找到次数了。

复制代码
class Solution {
    public int jump(int[] nums) {
        int n=nums.length;
        if(n==1)return 0;
        boolean []list=new boolean[n];
        
        int count=0;
        Queue<Integer>queue=new LinkedList();
        Queue<Integer>q=new LinkedList();
        queue.offer(n-1);
        for(int j=0;j<n;j++){
            if(j!=0){
                queue=q;
                q=new LinkedList();
            }
            for(int i=0;i<n;i++){
                int poi=-1;
                if(!queue.isEmpty()){
                    poi=queue.peek();
                }else{
                    break;
                }
                if(i+nums[i]>=poi){
                    list[i]=true;
                    q.offer(i);
                }
                if(i==poi)queue.poll();

            }
            count++;
            if(list[0])return count;
        }
        return count;


    }
}
相关推荐
叼烟扛炮8 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说9 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove9 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung10 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了10 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL10 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰10 小时前
C++ 排列组合完整指南
开发语言·c++·算法
代码中介商10 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法
foundbug99911 小时前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab
CN-Dust13 小时前
【C++】while语句例题专题
数据结构·c++·算法