USACO Training3.3 A Game【区间Dp】 By cellur925
一股浓浓的博弈论香气...然而本蒟并不会博弈论。
开始用双端队列+假的dp水过了24pts水数据。
其实是布星的,两人都绝顶聪明会深谋远虑不像我只看眼前,所以上述算法错误。
正解:区间dp。决策有两种:从右边取或是左边。而且答案是由小部分一步步推到大部分的,所以区间dp再适合不过啦。
状态:如常。$f[i][j]$表示拿从i到j玩家1得到的最大得分。
转移方程:$f[i][j]=max(sub[j]-sub[i-1]-f[i][j-1],sub[j]-sub[i-1]-f[i+1][j])$ sub[]是前缀和数组。
第一个:当1拿了最右,则2拿i到j-1,剩下的归1;第二个同理。
目标:$f[1][n]$ (玩家1) $sub[n]-f[1][n]$(玩家2)
Code
#include<cstdio>
#include<algorithm> using namespace std; int n;
int a[],sub[];
int f[][]; int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d",&a[i]),sub[i]=sub[i-]+a[i],f[i][i]=a[i];
for(int i=n-;i>=;i--)
for(int j=i+;j<=n;j++)
f[i][j]=max(sub[j]-sub[i-]-f[i+][j],sub[j]-sub[i-]-f[i][j-]);
printf("%d %d",f[][n],sub[n]-f[][n]);
return ;
}
这么水都不会,我好菜呀。。。
Update:倒序循环的原因 $f[i][j]$需要从$f[i+1][j]$转移过来...
USACO Training3.3 A Game【区间Dp】 By cellur925的更多相关文章
- [BZOJ 1652][USACO 06FEB]Treats for the Cows 题解(区间DP)
		[BZOJ 1652][USACO 06FEB]Treats for the Cows Description FJ has purchased N (1 <= N <= 2000) yu ... 
- P2339 提交作业usaco(区间dp)
		P2339 提交作业usaco 题目背景 usaco 题目描述 贝西在哞哞大学选修了 C 门课,她要把所有作业分别交给每门课的老师,然后去车站和同学们一起回家.每个老师在各自的办公室里,办公室要等他们 ... 
- poj 3186 Treats for the Cows(区间dp)
		Description FJ has purchased N (1 <= N <= 2000) yummy treats for the cows who get money for gi ... 
- 浅谈区间DP的解题时常见思路
		一.区间DP解题时常见思路 如果题目中答案满足: 大的区间的答案可以由小的区间答案组合或加减得到 大的范围可以由小的范围代表 数据范围较小 我们这时可以考虑采用区间DP来解决. 那么常见的解法有两种: ... 
- luogu1005矩阵取数游戏题解--区间DP
		题目链接 https://www.luogu.org/problemnew/show/P1005 分析 忽然发现这篇题解好像并没有什么意义...因为跟奶牛零食那道题一模一样,博主比较懒如果您想看题解的 ... 
- 【BZOJ-4380】Myjnie      区间DP
		4380: [POI2015]Myjnie Time Limit: 40 Sec Memory Limit: 256 MBSec Special JudgeSubmit: 162 Solved: ... 
- 【POJ-1390】Blocks      区间DP
		Blocks Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 5252 Accepted: 2165 Descriptio ... 
- 区间DP LightOJ 1422 Halloween Costumes
		http://lightoj.com/volume_showproblem.php?problem=1422 做的第一道区间DP的题目,试水. 参考解题报告: http://www.cnblogs.c ... 
- BZOJ1055: [HAOI2008]玩具取名[区间DP]
		1055: [HAOI2008]玩具取名 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1588 Solved: 925[Submit][Statu ... 
随机推荐
- Scrambled Polygon--poj2007(极角排序模板)
			http://poj.org/problem?id=2007 #include<stdio.h> #include<math.h> #include<algorithm& ... 
- 使用Spring Data Redis操作Redis(集群版)
			说明:请注意Spring Data Redis的版本以及Spring的版本!最新版本的Spring Data Redis已经去除Jedis的依赖包,需要自行引入,这个是个坑点.并且会与一些低版本的Sp ... 
- sql server2008 R2 各个版本的区别与选择
			目前已知的SQL Server 2008 R2的版本有: 企业版.标准版.工作组版.Web版.开发者版.Express版.Compact 3.5版. 这个次序也是各个版本功能的强大程度从高到低的一个排 ... 
- CentOS 6.x ELK(Elasticsearch+Logstash+Kibana)
			CentOS 6.x ELK(Elasticsearch+Logstash+Kibana) 前言 Elasticsearch + Logstash + Kibana(ELK)是一套开源的日志管理方案, ... 
- Qt移动应用开发(四):应用粒子特效
			Qt移动应用开发(四):应用粒子特效 上一篇文章介绍了Qt Quick是如何对帧动画进行支持的.帧动画的实现离不开状态机.而状态机.动画和状态切换(transitions)则是Qt框架的核心内容.也就 ... 
- Jenkins系列之-—02 email-ext 邮件模板
			邮件通知配置 系统管理 → 系统设置 → 邮件通知 SMTP 服务器:配置 SMTP 服务器.(不填默认本地运行服务器) 用户默认邮件后缀:注册用户邮件只需填写用户名即可,后缀会加该后缀,如果填写,则 ... 
- ssh配置无password登录
			前提.机器A,B,均为RedHat Linux操作系统,均实用户user 1.以usernameuser登录,在A机器上运行 ssh-keygen -t rsa 一路回车.不须要输入password ... 
- QC ALM 11创建域、项目和用户
			一旦HP-ALM安装,我们仅仅能继续创建域.项目和用户使用后的ALM工作.以下是步骤来创建项目.域和用户. 一.创建域 1.对于创建域,第一步是进入站点管理员页面.开展QC使用URL - ... 
- mysql备份及还原
			mysql怎样复制数据库?或者说,将数据库拷贝到另外一台机? 按照我的理解,复制数据库,如果是: 1.直接拷贝数据库文件,应该先停数据服务,否则拷不出来.但是,生产机器,哪能说停就停呢? 2.在线拷贝 ... 
- 2016/3/31  拾遗   php字符串中  转义字符   “ ’‘ ”    ’ “” ‘     " \’  ' ' \‘  "    "  \"  ''  \ " "  使用
			<?php echo $str_string1='甲问:"你在哪里学的PHP?"'; echo "<br />"; echo $str_str ... 
