最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • LeetCode题解:55. 跳跃游戏,贪心,JavaScript,详细注释

    正文概述 掘金(LeeChen)   2020-12-22   329

    原题链接:leetcode-cn.com/problems/ju…

    解题思路:

    1. 该题其实并不需要真正模拟跳跃,而是要知道从第一点开始跳,最远可以达到的索引是多少。
    2. 例如遍历[2,3,1,1,4]
      • 从索引0最多可以跳到2(0+2),那么0~2都在可到达的范围内。
      • 从索引1最多可到达4(1+3),即可以到达最后位置。
    3. 例如遍历[3,2,1,0,4]
      • 从索引0最多可以跳到3(0+3),那么0~3都在可达到的范围内。
      • 从1最多可以跳到3(1+2),从2最多可以跳到3(2+1),从3无法继续跳跃。
      • 因此从0开始跳,最多可到达的位置就是3,永远不可能到达4。
      • 当遍历到4时,当前索引已经超过了最多可到达位置3,也就是已经无法继续向前走,4之后的所有位置都无法到达。
    /**
     * @param {number[]} nums
     * @return {boolean}
     */
    var canJump = function(nums) {
      let max = 0 // 存储遍历到的所有位置向前走之后,可到达的最远位置
    
      for (let i = 0; i < nums.length; i++) {
        // 如果当前位置已经超过了最远位置,表示从之前的所有位置向前走,都不可能到达i及其之后的位置
        if (i > max) {
          return false
        }
    
        // 计算至今遍历到的所有位置,向前走nums[i]步后,可能到达的最大位置
        max = Math.max(max, i + nums[i])
    
        // 如果最远位置已可到达最后一个位置,即可退出循环
        if (max >= nums.length - 1) {
          return true
        }
      }
    };
    

    起源地下载网 » LeetCode题解:55. 跳跃游戏,贪心,JavaScript,详细注释

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元