news 2026/6/22 11:04:27

LeetCode 3652.按策略买卖股票的最佳时机:滑动窗口

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 3652.按策略买卖股票的最佳时机:滑动窗口

【LetMeFly】3652.按策略买卖股票的最佳时机:滑动窗口

力扣题目链接:https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-using-strategy/

给你两个整数数组pricesstrategy,其中:

  • prices[i]表示第i天某股票的价格。
  • strategy[i]表示第i天的交易策略,其中:
    • -1表示买入一单位股票。
    • 0表示持有股票。
    • 1表示卖出一单位股票。

同时给你一个偶数整数k,你可以对strategy进行最多一次修改。一次修改包括:

  • 选择strategy中恰好k连续元素。
  • 将前k / 2个元素设为0(持有)。
  • 将后k / 2个元素设为1(卖出)。

利润定义为所有天数中strategy[i] * prices[i]总和

返回你可以获得的最大可能利润。

注意:没有预算或股票持有数量的限制,因此所有买入和卖出操作均可行,无需考虑过去的操作。

示例 1:

输入:prices = [4,2,8], strategy = [-1,0,1], k = 2

输出:10

解释:

修改策略利润计算利润
原始[-1, 0, 1](-1 × 4) + (0 × 2) + (1 × 8) = -4 + 0 + 84
修改 [0, 1][0, 1, 1](0 × 4) + (1 × 2) + (1 × 8) = 0 + 2 + 810
修改 [1, 2][-1, 0, 1](-1 × 4) + (0 × 2) + (1 × 8) = -4 + 0 + 84

因此,最大可能利润是 10,通过修改子数组[0, 1]实现。

示例 2:

输入:prices = [5,4,3], strategy = [1,1,0], k = 2

输出:9

解释:

修改策略利润计算利润
原始[1, 1, 0](1 × 5) + (1 × 4) + (0 × 3) = 5 + 4 + 09
修改 [0, 1][0, 1, 0](0 × 5) + (1 × 4) + (0 × 3) = 0 + 4 + 04
修改 [1, 2][1, 0, 1](1 × 5) + (0 × 4) + (1 × 3) = 5 + 0 + 38

因此,最大可能利润是 9,无需任何修改即可达成。

提示:

  • 2 <= prices.length == strategy.length <= 105
  • 1 <= prices[i] <= 105
  • -1 <= strategy[i] <= 1
  • 2 <= k <= prices.length
  • k是偶数

解题方法:滑动窗口

既然修改范围是定长的,并且最多修改1次,那么就从前往后将每一种修改可能都试试呗。

初始先计算原数组不修改时收益,再从前往后依次尝试修改区间,取收益最大的一个作为答案。

如何从一个区间快速计算出下一个区间呢?变化的有3个:(变化前的)区间起点、区间中点、区间终点,把这三个位置的值更新一下就好了。

  • 时间复杂度O ( l e n ( p r i c e s ) ) O(len(prices))O(len(prices))
  • 空间复杂度O ( 1 ) O(1)O(1)

AC代码

C++
/* * @LastEditTime: 2025-12-18 18:42:50 */typedeflonglongll;classSolution{public:llmaxProfit(vector<int>&prices,vector<int>&strategy,intk){ll ans=0;intn=prices.size();for(inti=0;i<n;i++){ans+=strategy[i]*prices[i];}ll now=ans;for(inti=0;i<k/2;i++){now+=(0-strategy[i])*prices[i];}for(inti=k/2;i<k;i++){now+=(1-strategy[i])*prices[i];}ans=max(ans,now);for(inti=1;i+k<=n;i++){// i-1: 0->original// i+k/2-1: 1->0// i+k-1: original->1now+=(strategy[i-1]-0)*prices[i-1]+(0-1)*prices[i+k/2-1]+(1-strategy[i+k-1])*prices[i+k-1];ans=max(ans,now);}returnans;}};

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

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

Java资源合集

程序员《Java架构师实战训练营 (含完整资料)》 文件大小: 135.3GB内容特色: 135GB大厂级Java架构师全流程实战适用人群: 3年以上Java工程师冲刺架构师核心价值: 源码级落地分布式高并发项目速成下载链接: https://pan.quark.cn/s/49f75756e5e2 北京总部Java241125班_根据课程…

作者头像 李华
网站建设 2026/6/18 13:45:51

【每日算法】LeetCode 51. N 皇后

对前端开发者而言&#xff0c;学习算法绝非为了“炫技”。它是你从“页面构建者”迈向“复杂系统设计者”的关键阶梯。它将你的编码能力从“实现功能”提升到“设计优雅、高效解决方案”的层面。从现在开始&#xff0c;每天投入一小段时间&#xff0c;结合前端场景去理解和练习…

作者头像 李华
网站建设 2026/6/22 5:55:14

用户故事测试验收标准:从需求到质量的精准桥梁

在敏捷软件开发中&#xff0c;用户故事作为需求表达的核心载体&#xff0c;其测试验收标准&#xff08;Acceptance Criteria&#xff09;构成了开发团队、测试人员与产品经理之间的关键契约。根据2024年ISTQB行业调查报告显示&#xff0c;超过67%的软件缺陷源于需求理解不一致&…

作者头像 李华
网站建设 2026/6/22 3:51:29

测试团队的内外部沟通策略

沟通在测试中的核心价值软件测试不仅仅是技术活动&#xff0c;更是一种沟通密集型工作。测试团队通过沟通传递缺陷信息、风险预警和进度更新&#xff0c;而内外部沟通不畅往往导致项目延迟、缺陷遗漏或团队冲突。据统计&#xff0c;超过50%的项目问题源于沟通失败。因此&#x…

作者头像 李华
网站建设 2026/6/15 13:32:39

计算机提示network error怎么解决?超详细排查与修复教程

在使用电脑、手机、平板等设备上网时&#xff0c;network error是非常常见的问题。不管是浏览网页、刷视频、下载文件还是登录软件&#xff0c;一旦弹出network error提示&#xff0c;就意味着设备和网络之间的连接出现了故障。想要快速解决network error&#xff0c;我们可以按…

作者头像 李华