HJ98 喜欢切数组的红

知识点动态规划

描述

小红有一个长度为 n 的数组 {a1,a2,...,an},她打算将数组切两刀变成三个非空子数组,使得每一个子数组中至少存在一个正数,且每个子数组的和都相等。

看起来不是很难,所以小红想让你求解,一共有多少种不同的切分方案。

输入描述:

第一行输入两个整数 n(3≦n≦2×105) 代表数组中的元素数量。

第二行输入 n 个整数 a1,a2,...,an(−109≦ai≦109) 代表数组元素。

输出描述:

在一行上输出一个整数,代表切分方案数。

示例1

输入:

复制代码
3
3 3 3

输出:

复制代码
1

示例2

输入:

复制代码
6
1 1 4 5 1 4

输出:

复制代码
0

示例3

输入:

复制代码
10
0 3 4 2 3 2 1 -1 3 4

输出:

复制代码
2
cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
#define MXN 1000002
using namespace std;
inline void rd(ll &x){x=0;short f=1;char c=getchar();while((c<'0'||c>'9')&&c!='-') c=getchar();if(c=='-') f=-1,c=getchar();while(c>='0'&&c<='9') x=x*10+c-'0',c=getchar();x*=f;}
inline void pt(ll x){if(x<0) putchar('-'),x=-x;if(x>9) pt(x/10);putchar(x%10+'0');}
ll T=1,n,a[MXN],ne[MXN],nt[MXN],sum[MXN],f[MXN],ans;
void solve(){
    rd(n);
    for(ll i=1;i<=n;i++)
        rd(a[i]),ne[i]=ne[i-1]+(a[i]>0),sum[i]=sum[i-1]+a[i];
    if(sum[n]%3){puts("0");return;}
    nt[n+1]=n+1;
    for(ll i=n;i;i--)
        f[i]=f[i+1]+(ne[n]-ne[i-1]&&sum[n]-sum[i-1]==sum[n]/3),
        nt[i]=a[i]>0?i:nt[i+1];
    for(ll i=1;i<=n;i++)
        if(ne[i]&&sum[i]==sum[n]/3){
            ll r=nt[i+1];
            if(r<n) ans+=f[r+1];
        }
    pt(ans);
}int main(){while(T--) solve();}
相关推荐
兰令水1 小时前
leecodecode【面试150】【2026.6.14打卡-java版本】
java·算法·面试
凡人叶枫8 小时前
Effective C++ 条款30:透彻了解 inlining 的里里外外
linux·开发语言·c++·嵌入式开发·effective c++
noipp8 小时前
推荐题目:洛谷 P10907 [蓝桥杯 2024 国 B] 蚂蚁开会
c语言·c++·算法·编程·洛谷
学逆向的8 小时前
C++纯虚函数
开发语言·c++·网络安全
程序员二叉9 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
青山木9 小时前
Hot 100 --- 轮转数组
java·数据结构·算法
徐小夕9 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
凡人叶枫9 小时前
Effective C++ 条款22:将成员变量声明为 private
linux·开发语言·c++
北域码匠10 小时前
SHA-1算法:安全哈希原理与应用解析
算法·c#·哈希算法
坚果派·白晓明11 小时前
【鸿蒙PC】SDL3 移植:AtomCode Skills 4 步速通多媒体库适配
c++·华为·ai编程·harmonyos·atomcode·c/c++三方库