力扣2382. 删除操作后的最大子段和

力扣2382. 删除操作后的最大子段和

题目

题目解析及思路

题目要求找到每次删除一个元素的最大字段和

因为删除不好做,可以转删除为添加,用并查集维护当前子段和

两部分合并(两个并查集),三部分求和(两个并查集和一个元素)

代码

cpp 复制代码
class Solution {
public:
    vector<long long> maximumSegmentSum(vector<int>& nums, vector<int>& removeQueries) {
        int n = nums.size();
        //把数组看做一条链,最右边n的位置有一个虚拟头节点
        int p[n+1];
        iota(p,p+n+1,0);
        long long sum[n+1];
        memset(sum, 0, sizeof(sum));
        vector<long long> ans(n);
        function<int(int)> find = [&](int x) -> int { 
            return p[x] == x ? x : p[x] = find(p[x]); 
        };

        //反向操作
        for(int i=n-1;i>0;i--){
            int x = removeQueries[i];
            int fa = find(x+1);
            p[x] = fa;
            sum[fa] += sum[x] + nums[x];
            ans[i-1] = max(ans[i],sum[fa]);
        }
        return ans;
    }
};
相关推荐
董董灿是个攻城狮6 分钟前
Transformer 通关秘籍8:词向量如何表示近义词?
算法
独好紫罗兰28 分钟前
洛谷题单2-P5712 【深基3.例4】Apples-python-流程图重构
开发语言·python·算法
uhakadotcom39 分钟前
NVIDIA Resiliency Extension(NVRx)简介:提高PyTorch训练的容错性
算法·面试·github
梭七y1 小时前
【力扣hot100题】(020)搜索二维矩阵Ⅱ
算法·leetcode·职场和发展
v维焓1 小时前
C++(思维导图更新)
开发语言·c++·算法
ylfhpy1 小时前
Java面试黄金宝典22
java·开发语言·算法·面试·职场和发展
Phoebe鑫1 小时前
数据结构每日一题day9(顺序表)★★★★★
数据结构·算法
烁3472 小时前
每日一题(小白)动态规划篇2
算法·动态规划
南玖yy2 小时前
数据结构C语言练习(栈)
c语言·数据结构·算法
阿镇吃橙子3 小时前
一些手写及业务场景处理问题汇总
前端·算法·面试