122.买卖股票的最佳时机II
class Solution {
public:
int maxProfit(vector<int>& prices) {
int num=0;
int count=0;
for(int i=0;i<prices.size();i++){
if(i<prices.size()-1){
if(prices[i]<prices[i+1]){
if(num==0){
num++;
count-=prices[i];
}
}else{
if(num==1){
count+=prices[i];
num--;
}
}
}
if(i==prices.size()-1&&num==1)
count+=prices[i];
}
return count;
}
};
55. 跳跃游戏
每次移动取最大跳跃步数(得到最大的覆盖范围),每移动一个单位,就更新最大覆盖范围。
贪心算法局部最优解:每次取最大跳跃步数(取最大覆盖范围),整体最优解:最后得到整体最大覆盖范围,看是否能到终点。
class Solution {
public:
bool canJump(vector<int>& nums) {
if(nums.size()==1)
return true;
int count=0;
for(int i=0;i<nums.size()-1&&i<=count;i++){
if(nums[i]+i>count)
count = nums[i]+i;
}
if(count>=nums.size()-1)
return true;
else
return false;
}
};
45.跳跃游戏II
class Solution {
public:
int jump(vector<int>& nums) {
if(nums.size()==1) return 0;
int curdistance = 0;
int ans = 0;
int nextdistance = 0;
for(int i=0;i<nums.size();i++){
nextdistance = max(nums[i]+i,nextdistance);
if(i==curdistance){
ans++;
curdistance = nextdistance;
if(nextdistance>=nums.size()-1) break;
}
}
return ans;
}
};