目录
状态:贪心AC。
- class Solution {
- public:
- int maxProfit(vector<int>& prices) {
- int res = 0;
- int len = prices.size();
- for(int i = 1; i < prices.size(); ++i){
- res += max(prices[i] - prices[i-1], 0);
- }
- return res;
- }
- };
状态:查看思路后AC。
- class Solution {
- public:
- bool canJump(vector<int>& nums) {
- int cover = 0;
- if (nums.size() == 1) return true; // 只有一个元素,就是能达到
- for (int i = 0; i <= cover; i++) { // 注意这里是小于等于cover
- cover = max(i + nums[i], cover);
- if (cover >= nums.size() - 1) return true; // 说明可以覆盖到终点了
- }
- return false;
- }
- };
状态:没有思路。
- class Solution {
- public:
- int jump(vector<int>& nums) {
- int curDistance = 0; // 当前覆盖的最远距离下标
- int ans = 0; // 记录走的最大步数
- int nextDistance = 0; // 下一步覆盖的最远距离下标
- for (int i = 0; i < nums.size() - 1; i++) { // 注意这里是小于nums.size() - 1,这是关键所在
- nextDistance = max(nums[i] + i, nextDistance); // 更新下一步覆盖的最远距离下标
- if (i == curDistance) { // 遇到当前覆盖的最远距离下标
- curDistance = nextDistance; // 更新当前覆盖的最远距离下标
- ans++;
- }
- }
- return ans;
- }
- };