3652.按策略买卖股票的最佳时机:滑动窗口
【LetMeFly】3652.按策略买卖股票的最佳时机:滑动窗口
力扣题目链接:https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-using-strategy/
给你两个整数数组 prices 和 strategy,其中:
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 + 8 | 4 |
| 修改 [0, 1] | [0, 1, 1] | (0 × 4) + (1 × 2) + (1 × 8) = 0 + 2 + 8 | 10 |
| 修改 [1, 2] | [-1, 0, 1] | (-1 × 4) + (0 × 2) + (1 × 8) = -4 + 0 + 8 | 4 |
因此,最大可能利润是 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 + 0 | 9 |
| 修改 [0, 1] | [0, 1, 0] | (0 × 5) + (1 × 4) + (0 × 3) = 0 + 4 + 0 | 4 |
| 修改 [1, 2] | [1, 0, 1] | (1 × 5) + (0 × 4) + (1 × 3) = 5 + 0 + 3 | 8 |
因此,最大可能利润是 9,无需任何修改即可达成。
提示:
2 <= prices.length == strategy.length <= 1051 <= prices[i] <= 105-1 <= strategy[i] <= 12 <= k <= prices.lengthk是偶数
解题方法:滑动窗口
既然修改范围是定长的,并且最多修改1次,那么就从前往后将每一种修改可能都试试呗。
初始先计算原数组不修改时收益,再从前往后依次尝试修改区间,取收益最大的一个作为答案。
如何从一个区间快速计算出下一个区间呢?变化的有3个:(变化前的)区间起点、区间中点、区间终点,把这三个位置的值更新一下就好了。
- 时间复杂度$O(len(prices))$
- 空间复杂度$O(1)$
AC代码
C++
1 | |
同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~
千篇源码题解已开源
3652.按策略买卖股票的最佳时机:滑动窗口
https://blog.letmefly.xyz/2025/12/18/LeetCode 3652.按策略买卖股票的最佳时机/