news 2026/2/11 6:49:43

力扣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/2/10 18:41:25

硬核产品铸就品牌实力!苏州金龙荣获“影响中国客车业”两项大奖

2026年1月22日&#xff0c;中国土木工程学会城市公共交通分会、中国客车网联合主办的“第二十届影响客车业年度盘点新质生产力创新发展论坛暨公交客车科技交流对话”活动在北京隆重召开。苏州金龙旗下新V系V12商旅版与睿星轻型客车分别获评2025-2026年度“高端公商务车之星”与…

作者头像 李华
网站建设 2026/2/8 2:31:00

C86国产化云主机,天翼云构建全栈自主算力底座

政务、金融、能源等关键领域数字化转型对算力自主可控需求日益迫切&#xff0c;传统国产化云服务器面临性能不足、生态适配差、安全防护薄弱、迁移难度大等问题&#xff0c;制约规模化落地与业务深度适配。天翼云基于C86处理器打造新一代国产化云主机&#xff0c;深度整合国产硬…

作者头像 李华
网站建设 2026/2/6 18:37:41

基于Android的企业网络主机IP地址管理系统(源码+lw+部署文档+讲解等)

课题介绍 本课题旨在设计并实现基于 Android 的企业网络主机 IP 地址管理系统 APP&#xff0c;针对传统企业 IP 地址管理中人工台账易出错、地址分配混乱、设备绑定不清晰、故障排查效率低、移动端运维缺失等痛点&#xff0c;打造适配企业网络管理场景的移动化 IP 地址管控平台…

作者头像 李华
网站建设 2026/2/10 8:46:01

python+pytest接口自动化测试:接口测试基础详解

&#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 接口定义 一般我们所说的接口即API&#xff0c;那什么又是API呢&#xff0c;百度给的定义如下&#xff1a; API&#xff08;Application Programming Interf…

作者头像 李华