[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=;
for(int i=;i<nums.size()&&i<=count;i++){
count=max(count,i+nums[i]);
}
if(count<nums.size()-)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[]=;
for(int i=;i<n-;i++){
for(int j=i+;j<n&&j<=i+nums[i];j++)
dp[j]=min(dp[i]+,dp[j]);
}
return dp[n-];
}
};
第二种方法:贪心算法
我们可以把整个数组分成很多个区域,
把样例[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前,我们并不知道从现在区域到达的最远位置,必须不断更新寻找。
代码如下:
class Solution {
inline int max(const int a,const int b){return a>b?a:b;}
public:
int jump(vector<int>& nums) {
int newReach=;//记录从现在区域出发能到达的最远位置
int ans=;//记录次数
int currentReach=;//记录现在区域的最远位置
int n=nums.size();
for(int i=;i<n;i++){
if(i>currentReach){//超过现在区域的最远位置,说明进入了一个新区域,ans++
ans++;
currentReach=newReach;//更新现在区域的最远位置
}
newReach=max(newReach,i+nums[i]);//每次都更新从此区域出发的最远到达位置
}
return ans;
}
};
[Leetcode]44.跳跃游戏Ⅰ&&45.跳跃游戏Ⅱ的更多相关文章
- 贪心——55. 跳跃游戏 && 45.跳跃游戏II
给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 判断你是否能够到达最后一个位置. 示例 1: 输入: [2,3,1,1,4] 输出: true ...
- LeetCode 45. 跳跃游戏 II | Python
45. 跳跃游戏 II 题目来源:https://leetcode-cn.com/problems/jump-game-ii 题目 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素 ...
- Java实现 LeetCode 45 跳跃游戏 II(二)
45. 跳跃游戏 II 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 你的目标是使用最少的跳跃次数到达数组的最后一个位置. 示例: 输入: [ ...
- LeetCode 45跳跃游戏&46全排列
原创公众号:bigsai,回复进群加入力扣打卡群. 昨日打卡:LeetCode 42字符串相乘&43通配符匹配 跳跃游戏 题目描述: 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中 ...
- [leetcode] 45. 跳跃游戏 II(Java)(动态规划)
45. 跳跃游戏 II 动态规划 此题可以倒着想. 看示例: [2,3,1,1,4] 我们从后往前推,对于第4个数1,跳一次 对于第3个数1,显然只能跳到第4个数上,那么从第3个数开始跳到最后需要两次 ...
- leetcode 55. 跳跃游戏 及 45. 跳跃游戏 II
55. 跳跃游戏 问题描述 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 判断你是否能够到达最后一个位置. 示例 1: 输入: [2,3,1, ...
- Unity中制作游戏的快照游戏支持玩家拍快照
Unity中制作游戏的快照游戏支持玩家拍快照 有些游戏支持玩家“拍快照”,也就是将游戏的精彩瞬间以图片的形式记录下来的功能.这个功能比较有趣,而且以后的用途也会很广,为此本节打算介绍:截取矩形区域内游 ...
- C#开发Unity游戏教程之游戏对象的行为逻辑方法
C#开发Unity游戏教程之游戏对象的行为逻辑方法 游戏对象的行为逻辑——方法 方法(method),读者在第1章新建脚本时就见过了,而且在第2章对脚本做整体上的介绍时也介绍过,那么上一章呢,尽管主要 ...
- 直接操作游戏对象C#游戏开发
直接操作游戏对象C#游戏开发 2.2.3 直接操作游戏对象 在Inspector视图里通过设置属性而改变游戏场景中游戏对象的状态,太过抽象,毕竟数字并不够直观.其实,改变游戏对象的状态,完全有最最直 ...
随机推荐
- 2019.01.22 bzoj2874: 训练士兵(主席树)
传送门 题意简述:给出一个n∗mn*mn∗m的矩阵n,m≤1e8n,m\le1e8n,m≤1e8,支持矩形加,矩形求和,强制在线. 思路:第一眼二维动态开点线段树,上网去搜有没有这种做法发现会被卡时空 ...
- ip route 解释
[root@localhost ~]# ip route default via 172.16.0.1 dev ens192 proto static metric 100 172.16.0.0/16 ...
- mysql学习之路_字段类型与属性
回顾 数据库基本知识:关系型数据库与非关系型数据库 关系型数据库:安全(磁盘) 非关系型数据库:高效(内存) 关系型数据库:建立在关系模型上的数据库, 数据结构:二维表(浪费空间) 数据库操作指令:s ...
- svn 提交代码 自动过滤技巧
操作 在用svn管理版本时,有时希望在提交到服务器时,能过滤掉指定后缀名的所有文件,或指定名称的文件夹.文件名. 常见的文件夹名称和文件名如下: bin obj debug temppe *.suo ...
- java并发里的一些基础概念
转载自:https://my.oschina.net/hosee/blog/597934: 摘要: 本系列基于炼数成金课程,为了更好的学习,做了系列的记录. 本文主要介绍 1.高并发的概念,为以后系列 ...
- Effective C++ 随笔(2)
条款5 了解c++默默编写并调用哪些函数 编译器自动生成的copy 构造函数,copy赋值操作符,析构函数,构造函数,这些都是public和inline的,此处inline的意思是他们的定义都是在头文 ...
- onsyscommand
简介 OnSysCommand()这个函数主要是截获控制命令的,msdn上的解释如下: The framework calls this member function when the user s ...
- 【python-selenium】python-selenium安装配置
selenium 是一个web的自动化测试工具,不少学习功能自动化的同学开始首选selenium ,相因为它相比QTP有诸多有点: * 免费,也不用再为破解QTP而大伤脑筋 * 小巧,对于不同的语 ...
- 【python-pip】pip安装国外插件timeout解决方案
为什么会timeout呢,你懂得(不懂???!!!) 解决方案: 使用国内豆瓣镜像安装(也有其他的镜像,自己可以搜) pip install xxx -i http://pypi.douban.com ...
- Hdu 1009 FatMouse' Trade 2016-05-05 23:02 86人阅读 评论(0) 收藏
FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Tot ...