固定中间

lc2046

lc548

三指针------固定中间 预处理左右边

先算数组前缀和,用三个指针分四段区域

hash记录前两段相等的和

再找后两段和也相等且在哈希表中的情况

判断能否把数组分成和相等的四段

class Solution

{

public:

bool splitArray(vector<int>& nums)

{

int n = nums.size();

if (n < 7)

return false;

vector<int> presum(n + 1); //虚指

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

presumi + 1 = presumi + numsi;

// 3个指针,4个区域分别为 (1) L (2) M (3) R (4)

for (int M = 3; M < n - 3; M ++)

{

unordered_set<int> memo;

for (int L = 1; L < M - 1; L ++)

{ //找区域(1)和(2)相等的情况

int zoom1 = presumL;

int zoom2 = presumM - presumL + 1;

if (zoom1 == zoom2)

memo.insert(zoom1);

}

for (int R = M + 2; R < n - 1; R ++)

{ // (3)和(4)相等,且在memo中出现过(即==(1)==(2))

int zoom3 = presumR - presumM + 1;

int zoom4 = presumn - presumR + 1;

if (zoom3 == zoom4 && memo.count(zoom3))

return true;

}

}

return false;

}

};

相关推荐
小宋加油啊2 小时前
机械臂抓取物体 PVN3D算法调研学习
学习·算法·3d
lqqjuly2 小时前
前沿算法深度解析(一)
算法
小欣加油2 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
happymaker06265 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊5 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
八解毒剂7 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
运行时记录7 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
啦啦啦啦啦zzzz7 小时前
算法总结(二分查找、双指针)
c++·算法
qq_8573058198 小时前
python语法
开发语言·python·算法