5.14每日一题Optimal Partition

学习算法的小菜鸡 每日一题总教官 2022-05-14 13:44:54
加精
void solve() {
    int n;
    cin>>n;
    a[0]=ans[0]=0;
    bit[0].init(n);
    bit[1].init(n);
    for(int i=1; i<=n; i++)
    {
        cin>>a[i];
        a[i]+=a[i-1];
        mp[i]=a[i];
    }
    mp[n+1]=0;
    sort(mp+1,mp+n+2);
    unique(mp+1,mp+n+2);
    for(int i=0; i<=n; i++)
    {
        a[i]=lower_bound(mp+1,mp+n+2,a[i])-mp;
    }
    bit[0].add(a[0],0);
    bit[1].add(a[0],0);
    for(int i=1;i<=n;i++){
        ans[i]=ans[i-1]-1;
        ans[i]=max(ans[i],i+bit[0].get(a[i]-1));
        ans[i]=max(ans[i],bit[1].get(a[i]));
        bit[0].add(a[i],ans[i]-i);
        bit[1].add(a[i],ans[i]);
    }
    cout<<ans[n]<<endl;
}

 

...全文
37 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

50,796

社区成员

发帖
与我相关
我的任务
社区描述
和众多高校算法内卷分子,一起学习和交流算法那。浓郁的算法交流氛围,拒绝躺平,有效内卷。加入我们,私信我拉你入核心内卷群。
算法数据结构leetcode 个人社区
社区管理员
  • 执 梗
  • Dream-Y.ocean
  • ღCauchyོꦿ࿐
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

 刷题!

试试用AI创作助手写篇文章吧