【面试经典150题】买卖股票的最佳时机Ⅱ

题目链接

给你一个整数数组 prices ,其中 prices[i] 表示某支股票第 i 天的价格。

在每一天,你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买,然后在 同一天 出售。

返回 你能获得的 最大 利润

  • 1 <= prices.length <= 3 ∗ 1 0 4 3 * 10^4 3∗104
  • 0 <= prices[i] <= 1 0 4 10^4 104

两种情况:

  1. 当天买当天卖,获益为0。
  2. 当天买后天卖,获益prices[j]-prices[i]

要想利益最大,就要保证获益prices[j]-prices[i]不小于0。

javascript 复制代码
/**
 * @param {number[]} prices
 * @return {number}
 */
var maxProfit = function(prices) {
	let profit=0;
    for(let i=0;i<prices.length-1;i++){
        if(prices[i+1]>prices[i]){
            profit+=(prices[i+1]-prices[i]);
        }
    }
    return profit;
};
相关推荐
wayz1112 小时前
Day 5:KNN算法与相似K线匹配
人工智能·算法·机器学习
晨曦中的暮雨12 小时前
Java集合类型主要有哪些?以及各自原理
数据结构·算法
lixinnnn.13 小时前
01BFS:Three States
算法
晓纪同学13 小时前
EffctiveC++_第三章_资源管理
开发语言·c++·算法
阿珊和她的猫13 小时前
使用 TypeScript 实现数组类型判断方法
javascript·typescript·状态模式
XTTX11013 小时前
Vue3+Cesium电子围栏效果
前端·javascript·vue.js
水云桐程序员13 小时前
C语言编程基础,输入与输出
c语言·开发语言·算法
ZPC821013 小时前
MoveIt Servo 与自己编写的 Action Server 通信
人工智能·算法·机器人
jllllyuz13 小时前
采用核函数的极限学习机(KELM)MATLAB实现
算法
apcipot_rain13 小时前
【天梯赛】2026天梯赛模拟赛——题解
开发语言·c++·算法·蓝桥杯·天梯赛