news 2026/5/8 19:33:20

力扣122 买卖股票的最佳时机II java实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣122 买卖股票的最佳时机II java实现

122.买卖股票的最佳时机II

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

在每一天,你可以决定是否购买和/或出售股票。你在任何时候最多只能持有一股股票。然而,你可以在同一天多次买卖该股票,但要确保你持有的股票不超过一股。

返回你能获得的最大利润

示例 1:

输入:prices = [7,1,5,3,6,4]输出:7解释:在第 2 天(股票价格 = 1)的时候买入,在第 3 天(股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5 - 1 = 4。 随后,在第 4 天(股票价格 = 3)的时候买入,在第 5 天(股票价格 = 6)的时候卖出, 这笔交易所能获得利润 = 6 - 3 = 3。 最大总利润为 4 + 3 = 7 。

示例 2:

输入:prices = [1,2,3,4,5]输出:4解释:在第 1 天(股票价格 = 1)的时候买入,在第 5 天 (股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5 - 1 = 4。 最大总利润为 4 。

示例 3:

输入:prices = [7,6,4,3,1]输出:0解释:在这种情况下, 交易无法获得正利润,所以不参与交易可以获得最大利润,最大利润为 0。

提示:

  • 1 <= prices.length <= 3 * 104
  • 0 <= prices[i] <= 104

该题对比买卖股票的最佳时机题,多了一个可以多次买卖股票的条件,现在想使最终的利润最大化,可以用动态规划解决,设置dp[][]数组,dp[][]=dp[prices.length][2]。dp[i][0]表示第i天手里没有股票的最大利益,dp[i][1]表示第i天自上次卖出股票后到现在购买股票的最小值,例如,prices = [7,1,5,3,6,4],dp[0][1] = -7,因为一开始购买股票的最小值是7,dp[0][0]=0,dp[1][1]=-1,因为1小于7,当前购买的股票的最小值是1,dp[1][0]=0,紧接着dp[2][1] = -5当前股票价值上涨,直接卖出,最小的股票价值是5,dp[2][0]= 0+5-1=4,然后继续dp[3][1]=-3,由于今天购买股票的更低,dp[3][0]保持不变dp[3][0]=4,然后dp[4][1] = -6,今天股票价值上涨,直接卖出,再次购买股票的最低价值就是今天,dp[4][0] = dp[3][0] + dp[3][1] + 6 = 4 - 3 + 6 = 7,后续则可得出最大值为7。代码如下

public static void main(String[] args) { // 测试用 int[] prices = {7,1,5,3,6,4}; System.out.println(maxProfit(prices)); } public static int maxProfit(int[] prices) { int[][] dp = new int[prices.length][2]; dp[0][1] = -prices[0]; for (int i = 1; i < prices.length; i++) { if (dp[i - 1][0] < dp[i - 1][1] + prices[i] + dp[i - 1][0]){ dp[i][0] = dp[i - 1][1] + prices[i] + dp[i - 1][0]; dp[i][1] = -prices[i]; }else { dp[i][0] = dp[i - 1][0]; dp[i][1] = Math.max(dp[i - 1][1], -prices[i]); } } return dp[prices.length - 1][0]; }

以上为记录分享用,代码较差请见谅

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/2 16:19:59

互联网医院系统|互联网医院成品|互联网医院开发

互联网医院系统的兴起&#xff0c;正悄然改变传统医疗服务的边界与模式。通过技术赋能&#xff0c;医疗资源得以跨越时空限制&#xff0c;为患者提供更高效、便捷的诊疗体验。这一系统不仅整合了在线问诊、电子处方、药品配送、慢病管理等核心功能&#xff0c;还通过数据互联打…

作者头像 李华
网站建设 2026/4/28 11:18:04

APS概念-新订单开始日期延迟

一、核心概念解读新订单开始日期延迟是 APS 系统中为新插入的订单预留缓冲时间的参数&#xff0c;它会在订单正式排程前&#xff0c;提前一段固定的小时数来完成文书、采购、准备等前置工作&#xff0c;避免因紧急插单导致的生产混乱。二、关键作用与场景应对紧急插单当客户订单…

作者头像 李华
网站建设 2026/5/8 1:32:08

学霸同款AI论文平台TOP8:研究生开题报告神器测评

学霸同款AI论文平台TOP8&#xff1a;研究生开题报告神器测评 学术写作工具测评&#xff1a;为何需要这份2026年榜单 随着AI技术在学术领域的深入应用&#xff0c;越来越多的研究生开始依赖智能写作平台提升论文效率。然而&#xff0c;面对市场上琳琅满目的AI论文工具&#xf…

作者头像 李华
网站建设 2026/5/8 1:32:08

腾讯云TSearch存算分离,破解日志分析算力瓶颈

腾讯云TSearch存算分离&#xff0c;破解日志分析算力瓶颈随着企业数字化深入&#xff0c;日志分析、运维监控等场景的数据量呈爆炸式增长&#xff0c;传统存算一体架构逐渐暴露致命短板&#xff1a;写入压力集中导致带宽瓶颈&#xff0c;冷热数据混布拖累查询性能&#xff0c;多…

作者头像 李华
网站建设 2026/5/8 1:33:06

软件测试基础详解

&#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 一、软件测试概述 1、什么是软件 定义&#xff1a;计算机系统中与硬件相互依存的一部分&#xff08;程序数据相关文档&#xff09; 程序&#xff1a;按事先设…

作者头像 李华