1 LeetCode121.买卖股票的最佳时机(LeetCode121)
1.1 题目描述
题目描述如下:
示例如下:
1.2 问题分析及解决
要求最大利润,即当天与之前天的价格之差最大值。因此我们可以遍历数组,记录下当前遇到的最小值,然后用当天的价格减最小值得到利润,选择遍历整个数组的最大利润即可:
cpp
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
。
cpp
class Solution {
public:
bool canJump(vector<int>& nums) {
int maxstep=nums[0];
for(int i=1;i<nums.size();i++){
//每次跳跃一步
maxstep--;
//如果没有步数向前则返回false
if(maxstep<0) return false;
//否则更新自己能跳跃的最大步数
maxstep=max(maxstep,nums[i]);
}
return true;
}
};