LeetCode 055 Jump Game
2016-06-23 23:06
323 查看
题目大意:给出一个非负整数数组,开始你站在第一个数字上。当前位置的数字表示你最多能往下跳多远。问能否跳到最后一个数字上。
同45题Jump Game II类似。
记录当前能跳到的位置cur,和下一步能跳到的位置next。从数组的第一个位置开始扫描,如果cur小于当前位置,判断next是否也小于当前位置,如果是就返回false,否则用next更新cur。然后从当前位置再跳一步的最远位置是否大于next,如果是就更新next。最后如果cur大于数组的末尾位置就返回true。
代码:
同45题Jump Game II类似。
记录当前能跳到的位置cur,和下一步能跳到的位置next。从数组的第一个位置开始扫描,如果cur小于当前位置,判断next是否也小于当前位置,如果是就返回false,否则用next更新cur。然后从当前位置再跳一步的最远位置是否大于next,如果是就更新next。最后如果cur大于数组的末尾位置就返回true。
代码:
bool canJump(vector<int>& nums) { int cur, next; cur = nums[0]; next = nums[0]; for(int i = 1 ; i < nums.size() ; i++) { if(cur < i) { if(next < i) return false; cur = next; } if(i + nums[i] > next) next = i + nums[i]; if(cur >= nums.size() - 1) return true; } return true; }
相关文章推荐
- leetcode 179 Largest Number
- leetcode 24 Swap Nodes in Pairs
- leetcode 2 Add Two Numbers 方法1
- leetcode 2 Add Two Numbers 方法2
- leetcode----Longest Substring Without Repeating Characters
- [LeetCode]47 Permutations II
- [LeetCode]65 Valid Number
- [LeetCode]123 Best Time to Buy and Sell Stock III
- [LeetCode] String Reorder Distance Apart
- [LeetCode] Sliding Window Maximum
- [LeetCode] Find the k-th Smallest Element in the Union of Two Sorted Arrays
- [LeetCode] Determine If Two Rectangles Overlap
- [LeetCode] A Distance Maximizing Problem
- leetcode_linearList
- leetcode_linearList02
- 021-Merge Two Sorted Lists(合并两个排好序的单链表);leetcode
- LeetCode[Day 1] Two Sum 题解
- LeetCode[Day 2] Median of Two Sorted Arrays 题解
- LeetCode[Day 3] Longest Substring Without... 题解
- LeetCode [Day 4] Add Two Numbers 题解