题目描述

贝西和邦妮找到了一个藏宝箱,里面都是金币! 
但是身为两头牛,她们不能到商店里把金币换成好吃的东西,于是她们只能用这些金币来玩游戏了。  
 藏宝箱里一共有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. LeetCode_232-Implement Queue using Stacks

    题意是使用栈实现队列:队列是先进先出,后进后出. class MyQueue { public: /** Initialize your data structure here. */ MyQueue ...

  2. Warfare And Logistics UVA - 1416

    题目链接:https://vjudge.net/problem/UVA-1416 题解: 这是一个最短路的好题,首先我们考虑如果暴力弗洛伊德,显然时间复杂度不对,如果做n次spfa好像复杂度也不对,所 ...

  3. Java 的基本程序设计结构

    从Hello Word入手 public class HelloWorld { /* 第一个Java程序 */ public static void main(String[] args) { Sys ...

  4. 「3D建模」ZBrush如何雕刻头部

    加载项目开始 1. 如果未显示灯箱,请按逗号(,)或灯箱按钮. 2. 单击项目选项卡,然后双击DefaultSphere项目.它将被加载到ZBrush中. 3. 在工具>几何子选项板中,将SDi ...

  5. R-plotly|交互式甘特图(Gantt chart)-项目管理/学习计划

    本文首发于“生信补给站”微信公众号,https://mp.weixin.qq.com/s/CGz51qOjFSJ4Wx_qOMzjiw 更多关于R语言,ggplot2绘图,生信分析的内容,敬请关注小号 ...

  6. Detours 劫持

    在使用 Detours 劫持之前必须得拥有这两个东西:detours.h 和 detours.lib. 为了这两个东西我真的是弄了大半天,本着自己动手丰衣足食的思想: 我去 GitHub 克隆了一份来 ...

  7. VBS 去除文件夹下 Excel 的公式

    注意问题 window 环境下运行, 代码 ANSI 编码格式保存. 直接放到需要转换的文件夹下,双击运行. 代码 function getfolder() getfolder=left(wscrip ...

  8. python中使用logging将日志写入文件或输出到控制台

    import logging import os class Logger: def __init__(self, name=__name__): # 创建一个loggger self.__name ...

  9. Linux Centos7 基于Docker 搭建 Nexus私服搭建

    创建Blob Stores[本地文件存储目录,统一管理] 1.设置名称和工作路径: ps[注意事项]: 1.storage name:自定义名称 2.storage path:存储路径,默认[/nex ...

  10. 向net core 3.0进击——项目发布与部署

    目录 前言 发布 测试 小结 前言 在经历过好多折腾后,总算是把部署走通了一遍,之前只是简单创建个工程在linux下部署,后来一直将这件事搁置,直到最近刚好团队入手一个小服务器,很显然是linux的, ...