codeforces 383D
题意:
给你一个长为n的正整数数组,你要选一个连续子序列,对其每个元素加上正号或者负号,使其和为0,求方案数
题解:
dp( i , j , k )表示dp到第i个,和为j,这个元素是选了正还是负
滚动数组优化
1 #include<bits/stdc++.h> 2 #define ll long long 3 #define maxn 1005 4 #define maxm 10005 5 using namespace std; 6 const ll mod = 1000000007; 7 int n,a[maxn]; 8 ll dp[2][3][maxm*2]; 9 int main() 10 { 11 scanf("%d",&n); 12 for(int i=1;i<=n;++i)scanf("%d",&a[i]); 13 ll ans=0; 14 for(int i=1;i<=n;++i) 15 { 16 int now=i&1,pre=now^1; 17 memset(dp[now],0,sizeof(dp[now])); 18 dp[now][1][10005+a[i]]=1;dp[now][2][10005-a[i]]=1; 19 for(int k=1;k<=2;++k) 20 for(int j=0;j<maxm*2;++j)if(dp[pre][k][j]) 21 { 22 dp[now][1][j+a[i]]=(dp[now][1][j+a[i]]+dp[pre][k][j])%mod; 23 dp[now][2][j-a[i]]=(dp[now][2][j-a[i]]+dp[pre][k][j])%mod; 24 } 25 for(int k=1;k<=2;++k)ans=(ans+dp[i&1][k][10005])%mod; 26 } 27 printf("%I64d\n",ans); 28 return 0; 29 }
View Code
转载于:https://www.cnblogs.com/uuzlove/p/10465970.html
codeforces 383D相关推荐
- CodeForces 375D Tree and Queries
传送门:https://codeforces.com/problemset/problem/375/D 题意: 给你一颗有根树,树上每个节点都有其对应的颜色,有m次询问,每次问你以点v为父节点的子树内 ...
- 「日常训练」Bad Luck Island(Codeforces Round 301 Div.2 D)
题意与分析(CodeForces 540D) 是一道概率dp题. 不过我没把它当dp做... 我就是凭着概率的直觉写的,还好这题不算难. 这题的重点在于考虑概率:他们喜相逢的概率是多少?考虑超几何分布 ...
- 【codeforces 812C】Sagheer and Nubian Market
[题目链接]:http://codeforces.com/contest/812/problem/C [题意] 给你n个物品; 你可以选购k个物品;则 每个物品有一个基础价值; 然后还有一个附加价值; ...
- CodeForces 获得数据
针对程序的输出可以看见 CodeForces :当输入.输出超过一定字符,会隐藏内容 所以:分若干个程序进行输入数据的获取 1. 1 for (i=1;i<=q;i++) 2 { 3 scanf ...
- codeforces水题100道 第二十七题 Codeforces Round #172 (Div. 2) A. Word Capitalization (strings)...
题目链接:http://www.codeforces.com/problemset/problem/281/A 题意:将一个英文字母的首字母变成大写,然后输出. C++代码: #include < ...
- CodeForces 595A
题目链接: http://codeforces.com/problemset/problem/595/A 题意: 一栋楼,有n层,每层有m户,每户有2个窗户,问这栋楼还有多少户没有睡觉(只要一个窗户灯 ...
- codeforces A. Jeff and Digits 解题报告
题目链接:http://codeforces.com/problemset/problem/352/A 题目意思:给定一个只有0或5组成的序列,你要重新编排这个序列(当然你可以不取尽这些数字),使得这 ...
- Codeforces Round #506 (Div. 3)
Codeforces Round #506 (Div. 3) 实习期间事不多,对div3 面向题解和数据编程了一波 A. Many Equal Substrings 题目链接 A题就是找后缀和前缀重合 ...
- Codeforces Round #417:E. FountainsSagheer and Apple Tree(树上博弈)
Codeforces Round #417:E. FountainsSagheer and Apple Tree(树上博弈) 标签: codeforces 2017-06-02 11:41 29人阅读 ...
最新文章
- undo表空间暴长,如何取消自动扩展
- php中n12br,PHP常见字符串操作函数与用法总结
- 《利用python进行数据分析》读书笔记--第十章 时间序列(一)
- python数据挖掘学习笔记】十三.WordCloud词云配置过程及词频分析
- W3school和W3Cschool的区别
- ASP.NET的gridview设置数据格式DataFormatString(链接)
- 如何隐藏电脑下方工具栏个别图标_怎么隐藏电脑任务栏右边的各种小图标 - 卡饭网...
- UIButton高亮(highlighted)下的边框颜色(borderColor)
- C++小游戏(2):打飞机
- Oracle项目管理系统之项目投议标
- 验证google webrtc服务器demo(apprtc)使用的turn/stun服务器
- S7-1200PLC 基于以太网的TCP通信
- 题解 P4460 【[CQOI2018]解锁屏幕】
- 在绝望中寻找希望,把自己逼上成功
- 什么是DTO、VO、BO、PO、DO、POJO
- 【原创】VMware安装没有引导的Ghost镜像,超级详细,步步讲解
- C++ 继承(补充)
- 批量获取唯品会商品链接,详情页图片及视频保存技巧
- 数据库的设计规范:第一范式、第二范式、第三范式、巴斯范式
- Mitsubishi/三菱Q系列PLC ,QD77MS16走总线控制伺服项目,实际应用的,程序结构清晰明了
热门文章
- oracle数据库详细性能参数,ORACLE数据库性能参数的优化
- Android的自定义键盘颜色,android自定义键盘(解决弹出提示的字体颜色问题)
- c# timer 销毁_如果表单应用程序关闭C#,如何防止发生Timer Elapsed事件
- redis的两种持久化方式详解
- 自己打造Sublime Text 3 开发编辑神器
- Java可视化开发开源框架
- 华为鸿蒙系统支持智慧多屏吗,搭载鸿蒙OS!华为宣布企业智慧屏:多屏协同、底座带轮子...
- 网页打开慢与服务器有关吗,网站打开好慢! 原来是这些原因造成的
- log4jdbc mysql jdbc_spring boot 集成log4jdbc 查看完整sql
- 回归插补法_用均值替换、 回归插补及多重插补进行插补