固定中间

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;

}

};

相关推荐
BirdenT20 小时前
20260519紫题训练
c++·算法
csdn_aspnet1 天前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
谙弆悕博士1 天前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
gaosushexiangji1 天前
DIC系统推荐:基于千眼狼三维数字图像相关的无人机旋翼疲劳试验全场应变与位移测量
人工智能·算法
小王C语言1 天前
【线程概念与控制】:线程封装
jvm·c++·算法
kyle~1 天前
工程数学---点云配准卡布施(Kabsch)算法(求解最优旋转矩阵)
线性代数·算法·矩阵
张二娃同学1 天前
03_变量常量与输入输出_printf与scanf详解
算法
江南十四行1 天前
并发编程(一)
java·jvm·算法
z200509301 天前
今日算法(依旧二叉树)
算法·leetcode·职场和发展
Zxc_1 天前
《遗传算法:从自然选择到Rastrigin函数优化,手写一个完整的进化求解器》
算法