前后缀分解

lc3026

hash+动态记录前缀和

class Solution {

public:

long long maximumSubarraySum(vector<int> &nums, int k) {

long long ans = LLONG_MIN, sum = 0;

unordered_map<int, long long> min_s;

for (int x: nums) {

auto it = min_s.find(x + k);

if (it != min_s.end()) {

ans = max(ans, sum + x - it->second);

}

it = min_s.find(x - k);

if (it != min_s.end()) {

ans = max(ans, sum + x - it->second);

}

it = min_s.find(x);

if (it == min_s.end() || sum < it->second) {

min_s[x] = sum;

}

sum += x;

}

return ans == LLONG_MIN ? 0 : ans;

}

};

lc2588

class Solution {

public:

long long beautifulSubarrays(vector<int>& nums)

{

int k=0;

int n=nums.size();

vector<int> dp(n+1);

unordered_map<int,int> hash;

hash[0]=1;//dp[i]==k

long long ret=0;

for(int i=1;i<=n;i++)

{

dp[i]=dp[i-1]^nums[i-1];

if(hash[dp[i]])

ret+=hash[dp[i]];

hash[dp[i]]++;

}

return ret;

}

};

lc560

前缀和+hash

class Solution {

public:

int subarraySum(vector<int>& nums, int k) {

//子数组:连续的

int n=nums.size();

vector<int> dp(n+1);

unordered_map<int,int> count;

count[0]=1;//dp[i]==k

int ret=0;

for(int i=1;i<=n;i++)

{

dp[i]=dp[i-1]+nums[i-1];

if(count[dp[i]-k])

ret+=count[dp[i]-k];

count[dp[i]]++;

}

return ret;

}

};

lc3003 前后缀分解

解决"执行操作后的最大分割数"问题

处理字符串前缀、统计字符,结合修改一处字符的最优情况

计算出最大分割数量

class Solution {

public:

int maxPartitionsAfterOperations(string s, int k) {

if (k == 26) {

return 1;

}

int seg = 1, mask = 0, size = 0;

auto update = [&](int i) -> void {

int bit = 1 << (s[i] - 'a');

if (mask & bit) { // s[i] 已经在当前这一段中,无影响

return;

}

if (++size > k) {

seg++; // s[i] 在新的一段中

mask = bit;

size = 1;

} else {

mask |= bit;

}

};

int n = s.length();

vector<pair<int, int>> suf(n + 1);

for (int i = n - 1; i >= 0; i--) {

update(i);

suf[i] = {seg, mask};

}

int ans = seg; // 不修改任何字母

seg = 1; mask = 0; size = 0;

for (int i = 0; i < n; i++) {

auto [suf_seg, suf_mask] = suf[i + 1];

int res = seg + suf_seg; // 情况 3

int union_size = popcount((uint32_t) mask | suf_mask);

if (union_size < k) {

res--; // 情况 1

} else if (union_size < 26 && size == k && popcount((uint32_t) suf_mask) == k) {

res++; // 情况 2

}

ans = max(ans, res);

update(i);

}

return ans;

}

};

相关推荐
王老师青少年编程21 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮21 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说1 天前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove1 天前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung1 天前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了1 天前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL1 天前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰1 天前
C++ 排列组合完整指南
开发语言·c++·算法
代码中介商1 天前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法
foundbug9991 天前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab