Day15(贪心算法)——LeetCode121.买卖股票的最佳时机55.跳跃游戏
1 LeetCode121.买卖股票的最佳时机(LeetCode121)
1.1 题目描述
题目描述如下:
示例如下:
1.2 问题分析及解决
要求最大利润,即当天与之前天的价格之差最大值。因此我们可以遍历数组,记录下当前遇到的最小值,然后用当天的价格减最小值得到利润,选择遍历整个数组的最大利润即可:
class Solution {
public:int maxProfit(vector<int>& prices) {int minprice=INT_MAX;int maxprofit=INT_MIN;for(int i=0;i<prices.size();i++){//当前最便宜价格minprice=min(minprice,prices[i]);//当前最大利润maxprofit=max(maxprofit,prices[i]-minprice);}return maxprofit; }
};
2 LeetCode55.跳跃游戏(LeetCode55)
2.1 题目描述
题目描述如下:
具体示例如下:
2.2 问题分析及解决
贪心的思想,记录自己所能跳跃的最大值,每次只跳跃一步,每次跳跃一步时最大值减一,若小于0说明不能继续跳跃了,返回false
,否则返回跳跃到下一个位置,更新自己所能跳跃的最大值(即剩余步数和当前位置能跳跃的长度的最大值),若能遍历到所有位置则返回true
。
class Solution {
public:bool canJump(vector<int>& nums) {int maxstep=nums[0];for(int i=1;i<nums.size();i++){//每次跳跃一步maxstep--;//如果没有步数向前则返回falseif(maxstep<0) return false;//否则更新自己能跳跃的最大步数maxstep=max(maxstep,nums[i]);}return true;}
};