leetcode 3652(定长滑动窗口/前缀和)

3652: 按策略买卖股票的最佳时机

思路:定长滑动窗口 / 前缀和,枚举修改子数组 i−k,i−1

方法一:前缀和

计算两个前缀和数组:

  • 定义数组 c,其中 ci=pricesi⋅strategyi。计算 c 的前缀和,记作 sum
  • 计算 prices 的前缀和,记作 sum_sell

如果不修改,答案为 sumn

复制代码
class Solution {
public:
    long long maxProfit(vector<int>& prices, vector<int>& strategy, int k) {
        int n=prices.size();
        vector<long long> sum(n+1),sum_sell(n+1);
        //前缀和
        for(int i=0;i<n;i++){
            sum[i+1]=sum[i]+prices[i]*strategy[i];
            sum_sell[i+1]=sum_sell[i]+prices[i];
        }
        long long ans=sum[n];
        for(int i=k;i<=n;i++){
            long long res=sum[i-k]+sum[n]-sum[i]+sum_sell[i]-sum_sell[i-k/2];
            ans=max(ans,res);
        }

        return ans;
    }
};

方法二:定长滑动窗口

设不修改时的利润为 total。修改后,++利润(相比不修改)++增加了 sum (可能<0)。所有窗口的 sum 的最大值为 maxSum。那么答案为 total+max(maxSum,0)。这里可能出现 maxSum<0 的情况,此时不修改更好,也就是与 0 取最大值。

对于价格 p,如果修改前策略是 x,修改后策略是 y,那么利润增加了 p⋅(y−x)。比如原来买入,现在持有(不买入),那么利润增加了 p⋅(0−(−1))=p。又比如原来买入,现在卖出,那么利润增加了 p⋅(1−(−1))=2p。

下面计算每个窗口的 sum,考察从 i−k,i−1 向右滑到 i−k+1,i,sum 如何变化。

复制代码
class Solution {
public:
    long long maxProfit(vector<int>& prices, vector<int>& strategy, int k) {
        long long total=0,sum=0,max_sum=0;
        for(int i=0;i<prices.size();i++){
            int p=prices[i],s=strategy[i];
            total+=p*s;
            //入右半,交易策略从s变成1
            sum+=p*(1-s);
            //2<= k <=prices.length,尚未形成第一个窗口
            if(i<k-1){
                if(i>=k/2-1) sum-=prices[i-k/2+1]; //形成初始窗口时的左半边元素
                continue;
            }
            //更新
            max_sum=max(max_sum,sum);
            //对于下一个窗口,下标为i-(k/2-1)的元素从右半移到左半,交易策略从 1 变成 0;下标为 i-k+1 的元素从左半离开窗口
            sum-=prices[i-k/2+1]-prices[i-k+1]*strategy[i-k+1];
        }

        return total+max_sum;
    }
};
相关推荐
youngerwang8 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
想要成为糕糕手8 小时前
前端必修课:JavaScript 数组与数据结构底层逻辑全解析
javascript·数据结构·面试
KaMeidebaby8 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠9 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力10 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly10 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可12310 小时前
SolidWorks草图转三维DWG技巧
算法
tyung10 小时前
Go 手写 Wait-Free SPSC 无界队列:无 CAS、无锁、泛型节点池
数据结构·后端·go
redaijufeng11 小时前
C++雾中风景7:闭包
c++·算法·风景
Chen_harmony11 小时前
一、数据结构概念和复杂度计算
数据结构