当前位置: 首页 > news >正文

leetcode 123. 买卖股票的最佳时机 III

题目:123. 买卖股票的最佳时机 III - 力扣(LeetCode)

O(N)的算法:

f[i] = max(max(0, prices[i] - min(prices[0], prices[1], ... , prices[i - 1)), f[i - 1]);

g[i] = max(max(0, max(prices[i + 1], prices[i + 2], ... , prices[n - 1])), g[i + 1);

计算最大的 f[i - 1] + g[i] 即可

class Solution {
public:int maxProfit(vector<int>& prices) {int n = (int) prices.size();vector<int> f(n);vector<int> g(n);{int min = prices[0];f[0] = 0;for (int i = 1; i < n; i++) {if (prices[i] < min) min = prices[i];if (prices[i] - min > 0) {f[i] = prices[i] - min;} else {f[i] = 0;}if (f[i - 1] > f[i]) {f[i] = f[i - 1];}}}{int max = prices[n - 1];g[n - 1] = 0;for (int i = n - 2; i >= 0; i--) {if (prices[i] > max) max = prices[i];if (max - prices[i] > 0) {g[i] = max - prices[i];} else {g[i] = 0;}if (g[i + 1] > g[i]) {g[i] = g[i + 1];}}}int t;int ret = g[0];for (int i = 1; i < n; i++) {t = f[i - 1] + g[i];if (t > ret) {ret = t;}}return ret;}
};

http://www.lryc.cn/news/525184.html

相关文章:

  • Apache Tika 详解
  • ChatGPT被曝存在爬虫漏洞,OpenAI未公开承认
  • Qt——界面优化
  • python学opencv|读取图像(四十一 )使用cv2.add()函数实现各个像素点BGR叠加
  • Spring MVC和Spring WebFlux的区别
  • Linux探秘坊-------4.进度条小程序
  • Llama 3:开源大模型的里程碑式突破
  • 计算机网络 (56)交互式音频/视频
  • STM32 GPIO工作模式
  • 自动化实现的思路变化
  • MongoDB的索引与聚合
  • Java菜鸟养成计划(java基础)--java运算符
  • 除了基本的事件绑定,鸿蒙的ArkUI
  • 0164__【GNU】gcc -O编译选项 -Og -O0 -O1 -O2 -O3 -Os
  • vue3组件传值具体使用
  • Web 音视频(二)在浏览器中解析视频
  • 江天科技主要产品销售单价下滑,应收账款、存货周转率大幅下降
  • 我国的金融组织体系,还有各大金融机构的分类,金融行业的组织
  • vue md5加密
  • 学习ASP.NET Core的身份认证(基于JwtBearer的身份认证7)
  • Ubuntu16.04 安装OpenCV4.5.4 避坑
  • DDD - 整洁架构_解决技术设计困局
  • Python自动化运维:一键掌控服务器的高效之道
  • 数论问题61一一各种进位制
  • Java开发提速秘籍:巧用Apache Commons Lang工具库
  • 使用sql查询excel内容
  • [Python学习日记-78] 基于 TCP 的 socket 开发项目 —— 模拟 SSH 远程执行命令
  • 电子应用设计方案101:智能家庭AI喝水杯系统设计
  • vue学习路线
  • (15)Chainlink Automation(定时任务) 详细介绍及用法