买卖股票的最佳时机||
题目:给你一个整数数组 prices ,其中 prices[i] 表示某支股票第 i 天的价格。
在每一天,你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买,然后在 同一天 出售。
返回 你能获得的 最大 利润 。
思路:局部最优推出全局最优,如果前一天买入后一天卖出,如果收益是正的那么累加起来就是整个下来的收益最多的情况
例如:prices=[7,1,5,3,6,4]
p[3] - p[0] = p[1] - p[0] + p[2] - p[1] + p[3] - p[2]
所以3到0到区间上的收益最大值就是前一天买入后一天卖出的结果是正的累加,结果是负的就不要加了,因为最终的收益会变小
class Solution {
public int maxProfit(int[] prices) {
int res = 0;
// 因为要第二个减去第一个元素,所有i从1开始
for(int i = 1;i<prices.length;i++){
// 前一天买后一天卖的收益为正的时候就累加收益
if((prices[i] - prices[i-1]) > 0){
res += prices[i] - prices[i-1];
}
}
return res;
}
}
跳跃游戏
题目:给定一个非负整数数组 nums ,你最初位于数组的 第一个下标 。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标。
思路:我们使用cover
记录当前能够覆盖的最大的下标,如果能够覆盖到数组最后一个元素那么就说明可以跳到最后
class Solution {
public boolean canJump(int[] nums) {
if(nums.length == 1){
return true;
}
// 记录能够覆盖的最大的下标位置
int cover = 0;
// 这里为什么是i<=cover而不是i<nums.length,因为我们遍历的下标一定是要能够到达的,能够到达的也就是cover覆盖的下标
for(int i = 0;i<=cover;i++){
// 我们只需要保留最大的覆盖下标
cover = Math.max(cover,i+nums[i]);
// 当我们记录的覆盖的最大的下标大于了数组的最大的下标的时候就说明可以跳到最后了
if(cover >= nums.length - 1){
return true;
}
}
return false;
}
}
跳跃游戏||
题目:给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。
每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i + j] 处:
0 <= j <= nums[i]
i + j < n
返回到达 nums[n - 1] 的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]。
思路:如果当前可到达的位置发生变化就说明我们走了一步了
class Solution {
public int jump(int[] nums) {
if(nums.length == 1){
return 0;
}
int res = 0;
// 记录当前覆盖范围
int cur = 0;
// 记录下个覆盖范围
int next = 0;
// 这里只能遍历到倒数第二位
for(int i = 0;i<nums.length - 1;i++){
next = Math.max(next,i+nums[i]);
// 遇到改变覆盖范围就更新
if(cur == i){
res++;
cur = next;
}
}
return res;
}
}