[Leetcode]44.跳跃游戏Ⅰ&&45.跳跃游戏Ⅱ

跳跃游戏链接

给定一个非负整数数组,你最初位于数组的第一个位置。

数组中的每个元素代表你在该位置可以跳跃的最大长度。

判断你是否能够到达最后一个位置。

示例 1:

输入: [2,3,1,1,4]
输出: true
解释: 从位置 0 到 1 跳 1 步, 然后跳 3 步到达最后一个位置。

示例 2:

输入: [3,2,1,0,4]
输出: false
解释: 无论怎样,你总会到达索引为 3 的位置。但该位置的最大跳跃长度是 0 , 所以你永远不可能到达最后一个位置。

思路:

如果只是判断能否跳到终点,我们只要在遍历数组的过程中,更新每个点能跳到最远的范围就行了,

如果最后这个范围大于等于终点,就是可以跳到。

class Solution {
private:
    inline int max(const int a,const int b){return a>b?a:b;}

public:
    bool canJump(vector<int>& nums) {
        int count=0;
        for(int i=0;i<nums.size()&&i<=count;i++){
            count=max(count,i+nums[i]);
        }
        if(count<nums.size()-1)return false;
        return true;
    }
};

跳跃游戏Ⅱ现在来看跳跃问题一的衍生:

给定一个非负整数数组,你最初位于数组的第一个位置。

数组中的每个元素代表你在该位置可以跳跃的最大长度。

你的目标是使用最少的跳跃次数到达数组的最后一个位置。

示例:

输入: [2,3,1,1,4]
输出: 2
解释: 跳到最后一个位置的最小跳跃数是 2。
     从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。

说明:

假设你总是可以到达数组的最后一个位置。

第一种方法: 动态规划(超时)

定义状态dp[i]:到达位置i的最小步数

初始化dp: 0x3f3f3f3f,即一个极大值。

状态转移方程:对每个位置i为起点可以到达的位置j,都有dp[j]=min(dp[i]+1,dp[j]);

最后想要的结果:dp[n-1]

时间复杂度:O(n^2)

class Solution {
private: inline int min(const int a,const int b){return a>b?b:a;}
public:
    int jump(vector<int>& nums) {
        int n=nums.size();
        int dp[n];
        memset(dp,0x3f,sizeof(dp));
        /*初始化成最大值*/
        dp[0]=0;
        for(int i=0;i<n-1;i++){
            for(int j=i+1;j<n&&j<=i+nums[i];j++)
                dp[j]=min(dp[i]+1,dp[j]);
        }
        return dp[n-1];
    }
};

第二种方法:贪心算法

我们可以把整个数组分成很多个区域,

把样例[2,3,1,1,4]拿来做例子:

[2,3,1,1,4] 可以分成如左边三个区域,第i个区域代表从起点可以通过i-1步到达这些区域。

如何求上述分成上述区域呢?如下递归定义:

第1个区域就是起始位置一个。

第n个区域为(第n-1个区域最远的位置, 第n-1个区域为起点所到达的最远位置]

如何求这些区域呢,实际上可以遍历的过程中动态的求。

我们需要每次遍历的时候更新这些区域,实际上我们就用了两个变量currentReach和newReach区分区域,

前者记录现在区域的最远位置,newReach代表从这个区域能到达的最远位置。有上面我们可以知道下一个区域的范围为(currentReach,newReach]

因为我们只考虑最后一个点在第ans个区域而答案就是ans-1。遍历的过程中如果下标大于currentReach,说明进入了一个新的区域,区域就要更新。

newReach要不断更新的原因是,在到达currentReach前,我们并不知道从现在区域到达的最远位置,必须不断更新寻找。

代码如下:

 1 class Solution {
 2     inline int max(const int a,const int b){return a>b?a:b;}
 3 public:
 4     int jump(vector<int>& nums) {
 5         int newReach=0;//记录从现在区域出发能到达的最远位置
 6         int ans=0;//记录次数
 7         int currentReach=0;//记录现在区域的最远位置
 8         int n=nums.size();
 9         for(int i=0;i<n;i++){
10             if(i>currentReach){//超过现在区域的最远位置,说明进入了一个新区域,ans++
11                 ans++;
12                 currentReach=newReach;//更新现在区域的最远位置
13             }
14             newReach=max(newReach,i+nums[i]);//每次都更新从此区域出发的最远到达位置
15         }
16         return ans;
17     }
18 };

原文地址:https://www.cnblogs.com/adamwong/p/10222761.html

时间: 2024-11-09 09:42:06

[Leetcode]44.跳跃游戏Ⅰ&&45.跳跃游戏Ⅱ的相关文章

cocos2d-x游戏开发之游戏主循环

首先还是就我个人的理解,讲讲游戏引擎的处理流程. 其实游戏逻辑简单化就是一个死循环,如下: 1 2 bool game_is_running = true; 3 4 while( game_is_running ) { 5 update_game(); 6 display_game(); 7 } 我们所看到的游戏画面,游戏音乐,以及一些触控,输入等.在逻辑上就是这么一个死循环.这个循环一直在跑,期间会处理一些列的事件,简化之就是上面的两个函数. cocos2d-x引擎也是如此,所有的逻辑都是在这

Unity中制作游戏的快照游戏支持玩家拍快照

Unity中制作游戏的快照游戏支持玩家拍快照 有些游戏支持玩家"拍快照",也就是将游戏的精彩瞬间以图片的形式记录下来的功能.这个功能比较有趣,而且以后的用途也会很广,为此本节打算介绍:截取矩形区域内游戏视图,并将其显示在视图其它区域的方法.具体的操作步骤如下本文选自Unity游戏开发技巧集锦: (1)在Project视图里,创建一个C#脚本文件,并命名为ScreenTexture.在此脚本中编写如下的代码: 01     using UnityEngine; 02     using

C#开发Unity游戏教程之游戏对象的行为逻辑方法

C#开发Unity游戏教程之游戏对象的行为逻辑方法 游戏对象的行为逻辑--方法 方法(method),读者在第1章新建脚本时就见过了,而且在第2章对脚本做整体上的介绍时也介绍过,那么上一章呢,尽管主要内容是变量,但是在章节的最后为了展示游戏效果,也用到了它.现在看来方法真的是无处不在,并且不可或缺.它甚至都可以影响游戏对象的行为逻辑!因此本章终于到了不得不介绍它的时候了. Unity游戏对象的行为逻辑 游戏场景中,有些游戏对象是静止的,例如,树木.山峰.石头等等.而另外一些游戏对象则是运动的,它

使用AxureRP7.0制作经典数独小游戏原型,axure游戏原型下载

之前,有同学在Q群中提问,如何使用axure制作经典数独解谜小游戏,当时由于时间关系没有来得及亲手制作,而是给同学们提供了Axure6.5版本的一个数独解谜游戏的原型,本教程由axure原型库网站录制,转载请注明出处!但是那个原型做的太过繁杂,所以仅供大家参考交流:在此,金乌老师特地抽时间给同学们使用AxureRP7.0制作了一下,感觉对实战逻辑分析和axure变量的掌握比较有考验,所以就放出来供大家学习交流使用. 在学习的过程中,如果你仅凭自己现有的对axure的掌握,无法准确分析并组织出原型

游戏编程与游戏种类

游戏编程指利用计算机编程语言,如C编程语言.C++.java等,编写计算机.手机或游戏机上的游戏. 目前流行的游戏编程语言为C++编程语言,目前流行的游戏编程接口为DirectX9.0,还有OpenGL.SDL(Simple DirectMedia Layer)等.现在手机上玩的游戏分为Android与IOS两种不同平台,分别是用eclipse/MyEclipse和xcode.现在也流行一些跨平台的编程引擎,例如cocos2d-x.unity 3D等. 简介 游戏编程指利用计算机编程语言,如C编

网页版《2048游戏》教程 - 游戏初始化

3.1.     初始化棋盘格 我们在main.js文件中,创建newgame()方法用于开始新的游戏.而开始新游戏需要完成两件事情,一是初始化棋盘格,一是在随机两个格子生成两个数字. $(function () { newgame(); }); function newgame() { // 初始化棋盘格 init(); // 在随机两个格子生成数字 generateOneNumber(); generateOneNumber(); } 我们通过编写init()方法来完成棋盘格的初始化工作.棋

网页版《2048游戏》教程 - 游戏优化

1.     GameOver部分 下面我们来分析游戏是如何结束的.一种情况是棋盘格中没有空的格子了,一种情况是棋盘格中没有可以移动的格子了. 首先,完成isgameover()方法的逻辑. function isgameover() { if (nospace(board) && nomove(board)) { gameover(); } } 其次,完成棋盘格中没有空的格子. function nospace(board) { for (var i = 0; i < 4; i++

【转载】U3D 游戏引擎之游戏架构脚本该如何来写

原文:http://tech.ddvip.com/2013-02/1359996528190113.html Unity3D 游戏引擎之游戏架构脚本该如何来写 2013-02-05 00:48:48     发表评论 这篇文章MOMO主要想大家说明一下我在Unity3D游戏开发中是如何写游戏脚本的,对于Unity3D这套游戏引擎来说入门极快,可是要想做好却非常的难.这篇文章的目的是让哪些已经上手Unity3D游戏引擎的朋友学会如何更好的写游戏脚本,当然本文这紧紧是我这么多年对游戏开发的认知,你也

我来谈谈我的游戏经历和“游戏三境界”

说到三境界,很多人怕是首先想到王国维: 王国维在<人间词话>说:古今之成大事业.大学问者,必经过三种之境界:"昨夜西风凋碧树.独上高楼,望尽天涯路."此第一境也. "衣带渐宽终不悔,为伊消得人憔悴."此第二境也. "众里寻他千百度,蓦然回首,那人却在灯火阑珊处."此第三境也.此等语皆非大词人不能道.然遽以此意解释诸词,恐为晏欧诸公所不许也." 如果上面看不太懂的,请自行百度吧:)   由此我也想要总结一下我玩游戏的三境界:玩