力扣 55. 跳跃游戏 js

第一种方法
动态规划 从后向前

var canJump = function(nums) {
 //生成长度为输入数组长度并且值都为0的数组
  const dp=Array(nums.length).fill(0);
  dp[nums.length-1]=1;
  for(let i=nums.length-2;i>=0;i--)
    {
    //这里是为了防止跳跃越界的情况
      var maxlength=Math.min(nums.length-i-1,nums[i])
      for(let j=1;j<=maxlength;j++)
        {
          if(dp[j+i]===1)
            {
              dp[i]=1;
              break;
            }
        }
      if(dp[i]!==1)
        {
          dp[i]=-1;
        }
    }
  console.log(dp)
  if(dp[0]===1)
    {
      return true;
    }
    if(dp[0]===-1)
    {
      return false;
    }
};

第二种方法
当minJump为0时其就表示可以走到最后

var canJump = function(nums) {
  let minJump =nums.length-1;
  for(let i=nums.length-2;i>=0;i--){
    if(nums[i]+i>=minJump)
      {
        minJump=i;
      }
  }
  if (minJump===0)
    {
      return true;
    }
  else{
    return false;
  }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值