122.买卖股票的最佳时机II
只要后一天比前一天大 就把这两天的差值加一下
class Solution {
public:
int maxProfit(vector<int>& prices) {
int res = 0;
for(int i = 1; i < prices.size(); i++){
if(prices[i] > prices[i-1]){
res += prices[i] - prices[i-1];
}
}
return res;
}
};
55. 跳跃游戏
class Solution {
public:
bool canJump(vector<int>& nums) {
//能跳到的最远下标
int maxpos = 0;
for(int i = 0; i < nums.size(); i++){
//当前位置超过了跳跃距离
if(i > maxpos) return false;
maxpos = max(maxpos, i + nums[i]);
}
return true;
}
};
法2
将能跳跃的最大长度存下来,每遍历一步就减1,遇到更大的就更新长度,如果在没到倒数第二个(包括倒数第二个)之前长度就为0了返回false。
class Solution {
public:
bool canJump(vector<int>& nums) {
if(nums.size() == 1) return true;
if(nums[0]== 0) return false;
int index = nums[0];
for(int i = 1; i < nums.size()-1; i++){
index--;
if(index < nums[i]){
index = nums[i];
}
if(index == 0) return false;
}
return true;
}
};
45.跳跃游戏II
class Solution {
public:
int jump(vector<int>& nums) {
int maxpos = 0; //跳跃最远位置
int end = 0; //每次遍历的边界位置
int res = 0;
for(int i = 0; i < nums.size() - 1; i++){
maxpos = max(maxpos, i + nums[i]);
//到边界位置更新下一次遍历的边界位置
if(i == end){
res++;
end = maxpos;
}
}
return res;
}
};