思路:

DP[ i ] 代表以 i 结尾的方案数. dp[i] += sum[i] - sum[j - 1] != 0 ? dp[j] : 0 ;

对于100%的数据,满足1<=N<=105, |Ai|<=100

n 1e5呀,两层for,GG;

利用树状数组维护sum[i],存的是以sum[i]的方案数 ,

那么每次加上当前所有的方案,减去sum[i]的方案,就好了。

这里还有一个小问题就是 |sum[i]|<=1e7,所以先离散化一下就好了。

把当前所有前缀和的方案数加起来。。然后减掉以自己的方案数。

也可以用map.

树状数组维护。

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const LL mod=1e9+7;
const int N=1e5+10;
LL sval[N],sum[N];
LL dp[N];
int lowbit(int x)
{
return x&(-x);
}
LL Sum(int d)
{
LL ans=0;
while(d)
{
ans=(ans+sval[d])%mod;
d=d-lowbit(d);
}
return ans;
} void add(int d,LL val,int n)
{
while(d<=n)
{
sval[d]=(sval[d]+val)%mod;
d+=lowbit(d);
}
} vector<LL>xs;
int main()
{
LL n,a;
scanf("%lld",&n);
sum[0]=0;
xs.push_back(0);
for(int i=1;i<=n;i++)
{
scanf("%lld",&a);
sum[i]=sum[i-1]+a;
xs.push_back(sum[i]);
}
sort(xs.begin(),xs.end());
auto it=unique(xs.begin(),xs.end());
for(int i=0;i<=n;i++)
sum[i]=lower_bound(xs.begin(),it,sum[i])-xs.begin()+1;
memset(dp,0,sizeof(dp));
for(int i=0;i<=n;i++)
{
dp[i]+=Sum(xs.size());
dp[i]-=Sum(sum[i])-Sum(sum[i]-1);
dp[i]=(dp[i]+mod)%mod;
if(dp[i]==0)
dp[i]=1;
add(sum[i],dp[i],xs.size());
}
printf("%lld\n",dp[n]);
return 0;
}

map维护

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const LL mod=1e9+7;
const int N=1e5+10;
LL sum[N];
LL dp[N];
map<int,int>mp; int main()
{
LL n,a;
scanf("%lld",&n);
sum[0]=0;
mp.clear();
for(int i=1;i<=n;i++)
{
scanf("%lld",&a);
sum[i]=sum[i-1]+a;
}
memset(dp,0,sizeof(dp));
dp[0]=1;
mp[0]=1;
LL cnt=1;
for(int i=1;i<=n;i++)
{
if(!mp.count(sum[i]))
{
dp[i]=cnt;
mp[sum[i]]=dp[i];
}
else
{
dp[i]=((cnt-mp[sum[i]])%mod+mod)%mod;
mp[sum[i]]=(mp[sum[i]]+dp[i]+mod)%mod;
}
cnt=(cnt+dp[i]+mod)%mod;
}
printf("%lld\n",dp[n]);
return 0;
}

hihocoder1475 数组分拆【DP+前缀和优化】的更多相关文章

  1. HDU 2829 区间DP & 前缀和优化 & 四边形不等式优化

    HDU 2829 区间DP & 前缀和优化 & 四边形不等式优化 n个节点n-1条线性边,炸掉M条边也就是分为m+1个区间 问你各个区间的总策略值最少的炸法 就题目本身而言,中规中矩的 ...

  2. [Codeforces712D] Memory and Scores(DP+前缀和优化)(不用单调队列)

    [Codeforces712D] Memory and Scores(DP+前缀和优化)(不用单调队列) 题面 两个人玩游戏,共进行t轮,每人每轮从[-k,k]中选出一个数字,将其加到自己的总分中.已 ...

  3. T2988 删除数字【状压Dp+前缀和优化】

    Online Judge:从Topcoder搬过来,具体哪一题不清楚 Label:状压Dp+前缀和优化 题目描述 给定两个数A和N,形成一个长度为N+1的序列,(A,A+1,A+2,...,A+N-1 ...

  4. Codeforces 479E. Riding in a Lift (dp + 前缀和优化)

    题目链接:http://codeforces.com/contest/479/problem/E 题意:         给定一个启示的楼层a,有一个不能去的楼层b,对于你可以去的下一个楼层必须满足你 ...

  5. 2018多校第九场 HDU 6416 (DP+前缀和优化)

    转自:https://blog.csdn.net/CatDsy/article/details/81876341 #include <bits/stdc++.h> using namesp ...

  6. BZOJ 1044: [HAOI2008]木棍分割 DP 前缀和优化

    题目链接 咳咳咳,第一次没大看题解做DP 以前的我应该是这样的 哇咔咔,这tm咋做,不管了,先看个题解,再写代码 终于看懂了,卧槽咋写啊,算了还是抄吧 第一问类似于noip的那个跳房子,随便做 这里重 ...

  7. Student's Camp CodeForces - 708E (dp,前缀和优化)

    大意: $n$行$m$列砖, 白天左侧边界每块砖有$p$概率被摧毁, 晚上右侧边界有$p$概率被摧毁, 求最后上下边界连通的概率. 记${dp}_{i,l,r}$为遍历到第$t$行时, 第$t$行砖块 ...

  8. 5.19 省选模拟赛 小B的夏令营 概率 dp 前缀和优化dp

    LINK:小B的夏令营 这道题是以前从没见过的优化dp的方法 不过也在情理之中. 注意读题 千万不要像我这个sb一样 考完连题意都不知道是啥. 一个长方形 要求从上到下联通的概率. 容易发现 K天只是 ...

  9. CDOJ ABCDE dp(前缀和优化)

    题目链接: http://acm.uestc.edu.cn/#/problem/show/1307 ABCDE Time Limit: 1000/1000MS (Java/Others)Memory ...

随机推荐

  1. curl下载安装

    curl下载地址 https://curl.haxx.se/download.html 选择windows generic 下的 下载安装 安装完后解压配置系统环境变量 CURL_HOME      ...

  2. LeetCode:子集 II【90】

    LeetCode:子集 II[90] 题目描述 给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: [1,2,2] 输出: ...

  3. 在Linux下创建7种类型的文件

    在测试的时候有时会需要每种类型的文件,在系统中进行搜索都会找到,当然最方便的还是手动创建它们进行测试使用. 普通文件: $ touch regular 目录: $ mkdir directory 符号 ...

  4. IOS AppStore介绍图的尺寸大小(还有一些自己被拒的分享...)

    4s:640*960 5:640*1136 6:750*1334 6P:1242*2208 -------现在新版本的iTunes connect里只上传6P版本的大小就可以了,其他版本苹果会自动分辨 ...

  5. BZOJ 2021 [Usaco2010 Jan]Cheese Towers:dp + 贪心

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2021 题意: John要建一个奶酪塔,高度最大为m. 他有n种奶酪.第i种高度为h[i]( ...

  6. BZOJ 1196 [HNOI2006]公路修建问题:二分 + 贪心生成树check(类似kruskal)

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1196 题意: n个城市,m对城市之间可以修公路. 公路有两种,一级公路和二级公路,在第i对 ...

  7. 查 101.201.62.30 IP信誉方法

    查 101.201.62.30 IP信誉方法https://www.virustotal.com/#/ip-address/101.201.62.30https://talosintelligence ...

  8. Servlet_03_部署描述符

    二.参考文档 1.Servlet 3.0 之 部署描述符 2.web.xml配置详解 部署描述符文件

  9. Java集合的有序无序问题和线程安全与否问题

    首先,清楚有序和无序是什么意思: 集合的有序.无序是指插入元素时,保持插入的顺序性,也就是先插入的元素优先放入集合的前面部分. 而排序是指插入元素后,集合中的元素是否自动排序.(例如升序排序) 1.有 ...

  10. Sox语音转换的相关知识

    SoX-linux 里操作音频的瑞士军刀 Sox是最为著名的Open Source声音文件 格式转换工具.已经被广泛移植到Dos.windows.OS2.Sun.Next.Unix.Linux等多个操 ...