题目描述

贝西和邦妮找到了一个藏宝箱,里面都是金币! 
但是身为两头牛,她们不能到商店里把金币换成好吃的东西,于是她们只能用这些金币来玩游戏了。  
 藏宝箱里一共有N枚金币,第i枚金币的价值是Ci。贝西和邦妮把金币排成一条直线,她们轮流取金币,看谁取到的钱最多。贝西先取,每次只能取一枚金币,而且只能选择取直线两头的金币,不能取走中间的金币。 
当所有金币取完之后,游戏就结束了。 贝西和邦妮都是非常聪明的,她们会采用最好的办法让自己取到的金币最多。 
请帮助贝西计算一下,她能拿到多少钱? 

输入

第1行:单个整数N,表示硬币的数量,1<=N≤5000  
第2~N+1行:第i+1行有一个整数Ci,代表第i块硬币的价值,1≤Ci≤5000 

输出

输出一行:单个整数,表示如果双方都按最优策略玩游戏,先手可以拿到的最大价值。

样例输入 Copy

4
30
25
10
35

样例输出 Copy

60

空间限制:64MB,n<=5000,开5000*5000的二维数组需要94MB的内存!!
题解:
首先,应该是一个n方(时间复杂度)的dp,看到空间果断是要压掉一维的。
n方的方程式:
f[i,j]=sum[i,j]-min(f[i+,j],f[i,j-]).
//强行解释:
f[i][j]表示从i到j取得最大值。
sum为前缀和,sum[i][j]就是i到j的累加和

注意了!!!!(划重点,敲黑板)这个方程式我一开始没有理解(不是最大值吗,为什么是min???(黑人问号脸)),后来看了一段时间,才发现:
这个方程式的意思是:贝西只能取左端点或者右端点的硬币,拿完了左或者右,剩下的i+1~j或者i~j-1个金币就由邦妮取了,min就是在贝西拿完金币之后,邦妮的“最大值”。
转化的思想:先手最优相当于后手最劣。以为题目并没有要求后手也是最优,所以我们就把邦妮的智商手动变低,找最大值得相对最小值,这时候贝西拿的就是最优了。(真骚气)

解决了方程的问题,来着手解决空间的问题。首先,没有卡时间,卡了空间,这就很难受了,只能努力用滚动数组来滚掉一维。

但是,当前的状态并不允许我们滚动。

因为以前写过一题类似的题目(貌似是区间dp),借鉴一下区间的板子,改变一下状态的表示方法(不是改变状态):

f[i,len]=sum[i,i+len]-min(f[i+1,len-1],f[i,len-1]).

f[i][len]表示从i开始,len长度(i+len=j)的最大值

不枚举j,而是枚举i(起点)和区间长度,但是时间复杂度却没有变。

这时候就能看出,第二维根本没有用(前后一样的)

于是就可以开心快落地滚掉一维了

代码短小精悍:

 #include<bits/stdc++.h>
using namespace std;
const int maxn=;
int n;
int sum[maxn];
int dp[maxn]; int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d",&dp[i]);
sum[i]=sum[i-]+dp[i];
}
for(int len=;len<=n;len++)
{
for(int i=;i+len<=n;i++)
{
dp[i]=sum[i+len]-sum[i-]-min(dp[i],dp[i+]); }
}
printf("%d",dp[]);
return ;
}

慢着!你以为到这就结束了?

↘         ↓          ↙

→    传送门     ←

↗         ↑          ↖

(完)

BZOJ 2101: [Usaco2010 Dec]Treasure Chest 藏宝箱(这是我写过最骚气的dp!)的更多相关文章

  1. BZOJ 2101: [Usaco2010 Dec]Treasure Chest 藏宝箱( dp )

    dp( l , r ) = sum( l , r ) - min( dp( l + 1 , r ) , dp( l , r - 1 ) ) 被卡空间....我们可以发现 l > r 是无意义的 ...

  2. BZOJ——2101: [Usaco2010 Dec]Treasure Chest 藏宝箱

    http://www.lydsy.com/JudgeOnline/problem.php?id=2101 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit:  ...

  3. BZOJ 2101 [Usaco2010 Dec]Treasure Chest 藏宝箱:区间dp 博弈【两种表示方法】【压维】

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2101 题意: 共有n枚金币,第i枚金币的价值是w[i]. 把金币排成一条直线,Bessie ...

  4. bzoj 2101: [Usaco2010 Dec]Treasure Chest 藏宝箱【区间dp】

    就是区间dp啦f[i][j]表示以i开头的长为j+1的一段的答案,转移是f[i][j]=s[i+l]-s[i-1]+min(f[i][j-1],f[i+1][j-1]),初始是f[i][1]=a[i] ...

  5. 【BZOJ】2101: [Usaco2010 Dec]Treasure Chest 藏宝箱(dp)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2101 这个dp真是神思想orz 设状态f[i, j]表示i-j先手所拿最大值,注意,是先手 所以转移 ...

  6. BZOJ2101: [Usaco2010 Dec]Treasure Chest 藏宝箱

    2101: [Usaco2010 Dec]Treasure Chest 藏宝箱 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 327  Solved:  ...

  7. bzoj21012101: [Usaco2010 Dec]Treasure Chest 藏宝箱(滚动数组优化dp)

    2101: [Usaco2010 Dec]Treasure Chest 藏宝箱 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 592  Solved:  ...

  8. [Usaco2010 Dec]Treasure Chest 藏宝箱

    题目链接:点这里 Solution: 刚开始以为是博弈论,然而不是... 首先考虑n方dp,设f(l,r)为只有\(l\)到\(r\)区间的钱的先手最大获利 那么我们可以得到式子f(l,r)=sum( ...

  9. bzoj2101【Usaco2010 Dec】Treasure Chest 藏宝箱

    2101: [Usaco2010 Dec]Treasure Chest 藏宝箱 Time Limit: 10 Sec  Memory Limit: 64 MB Submit: 418  Solved: ...

随机推荐

  1. 各种xml配置文件(所含内部标签及顺序)的提示功能是真的人性化

    通过mybatis generator的配置文件来举例,其他配置文件(web.xml,mybatis,spring,springmvc等)同理 mybatis可以通过mybatis generator ...

  2. 未来实现API管理系统的几个关键词

    下面将通过几个关键词的形式说明API管理的重要性和未来的实现方式. 1.生命周期管理 在整个API生命周期中更深入地集成所有工具将进一步提高生命周期循环的速度,而且更重要的是提供满足消费者需求的API ...

  3. node与mysql的相互使用————node+mysql

    node与mysql的相互使用----node+mysql 为什么选node???因为我是个前端. 为什么选mysql???因为成熟,稳定,听说容易学. 一.mysql数据库: mysql下载和使用我 ...

  4. drf框架中所有视图及用法

    0909自我总结 drf框架中所有视图及用法 一.drf框架中的所有视图类 from django.views import View from rest_framework import views ...

  5. java猜数游戏

    java随机数的产生 int number=(int)(Math.random()*10+1) Math.random()*n //n个随机数,从0开始 do{}while循环 //猜数,1到10的随 ...

  6. Python之网络编程Socket

    Python 提供了两个级别访问的网络服务.: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口的全部方法. 高级别的网络 ...

  7. Tensorflow从开始到放弃(技术篇)

    在gpu中运行 tf.device("/gpu:1") 有时候这个是会出问题的,即便你在有名称为1的gpu时.有的操作是不能支持gpu的,应该为session添加一些配置: pyt ...

  8. python 2.x中的中文

    先不管一大堆的中文显示的原理,在这里记录下正确显示中文的方式,便于以后的查阅和深入学习. 方法1 a = {} a["哈哈哈"] = "啦啦啦啦啦啦啦" s1 ...

  9. python学习-列表、元组和字典(三)

    学习笔记中的源码:传送门 3.1 列表和元组 3.2 不同类型变量的初始化: 数值 digital_value = 0 字符串 str_value = "" 或 str_value ...

  10. prefer-object-spread

    eslint报错: Use an object spread instead of `Object.assign` eg: `{ ...foo }`.(prefer-object-spread) 即: ...