固定中间

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++)

presum[i + 1] = presum[i] + nums[i];

// 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 = presum[L];

int zoom2 = presum[M] - presum[L + 1];

if (zoom1 == zoom2)

memo.insert(zoom1);

}

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

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

int zoom3 = presum[R] - presum[M + 1];

int zoom4 = presum[n] - presum[R + 1];

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

return true;

}

}

return false;

}

};

相关推荐
Wect2 小时前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP13 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱1 天前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub1 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP2 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP2 天前
一文搞懂激活函数!
算法·面试