● 122.买卖股票的最佳时机II
发现一个评论的思路,也挺不错的:
可以把股票的价格波动画出来,单调上升就是盈利,题解就是每一段单调上升的总和,
跟讲解的思路类似。
就是把连续几天的利润分解,分解成一天一天的利润。
class Solution {
public int maxProfit(int[] prices) {
int res = 0;
for(int i = 1;i<prices.length;i++){
res += Math.max(0,prices[i]-prices[i-1]) ;
}
return res;
}
}
● 55. 跳跃游戏
cover是覆盖范围
class Solution {
public boolean canJump(int[] nums) {
int cover = 0;
for(int i = 0;i<=cover;i++){
cover = Math.max(cover,i+nums[i]);//下标
if(cover>=nums.length-1) return true;
}
return false;
}
}
● 45.跳跃游戏II
cur和next是下标!!!
class Solution {
public int jump(int[] nums) {
if(nums.length==1) return 0;
int cur =0,next=0;
int res = 0;
for(int i = 0;i<nums.length;i++){
next = Math.max(i+nums[i],next);
if(i==cur){
res++;
cur = next;
if(next>=nums.length-1){
break;
}
}
}
return res;
}
}