博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 4701 Game
阅读量:6370 次
发布时间:2019-06-23

本文共 1283 字,大约阅读时间需要 4 分钟。

link:

DP真美 !  (亝 ‿ 亝)

 

dp[pos][a][b][0/1]:第pos件商品即将被购买,Alice有a元, Bob有b元,轮到谁行动(0:Alice 1:Bob)。

打训练赛时,设计出来了这样一个状态。然后发现了pos和a能表示出b呀!于是,省掉了一维,然后就不会

了。之后尝试着贪心,效果不佳。

 

先来个小小的降维~

dp[pos][x]:第pos件商品即将被购买,面临着这个局面的人有x元。能否获胜呢?

看来,求索未得啊!空间复杂度还是爆炸。然而dp[pos][x]仅仅表达0/1的话是不是有点浪费呢?这样来试试

dp[pos]:第pos件商品即将被购买,面临此局面的人至少需要多少元才可获胜?

nice!这个状态设计的挺令人满意的!

然后就可施展我们的博弈思想。若想胜,则需一个GG的后继.

即将行动的人的钱:dp[pos]

对手的钱:a+b - dp[pos] - sum[pos-1] 

 

为了找到这么一个后继,则存在nxt>pos满足这样两个条件:

dp[pos] >=  a + b - sum[pos-1] - dp[nxt] + 1  

dp[pos] >=  sum[nxt-1] - sum[pos-1]

令a + b - sum[pos-1] - dp[nxt] + 1 = Ans1, sum[nxt-1] - sum[pos-1] = Ans2

dp[pos] = min{ max(Ans1, Ans2) }

然后从后往前,一遍计算dp[i],一遍维护max(Ans1, Ans2)最小值。O(n)

#include 
using namespace std;typedef long long LL;const int NICO = 1000002;LL n, a, b, x;LL sum[NICO];int main(){ while(~scanf("%lld %lld %lld", &n, &a, &b)) { for(int i=1;i<=n;i++) { scanf("%lld", &x); sum[i] = sum[i-1] + x; } LL pre = sum[n], now = 0; for(int i=n;i>=1;i--) { now = pre - sum[i-1]; //cout << i << " : " << now << endl; pre = min(pre, max(sum[i-1], a+b-now+1)); } printf("%s\n", now>a?"BOB":"ALICE"); }}

  

 

转载于:https://www.cnblogs.com/RUSH-D-CAT/p/6854704.html

你可能感兴趣的文章
使用sysbench压力测试MySQL(一)(r11笔记第3天)
查看>>
css知多少(11)——position
查看>>
【Spring】定时任务详解实例-@Scheduled
查看>>
先有的资源,能看的速度看,不能看的,抽时间看。说不定那天就真的打不开了(转)...
查看>>
哪些领域适合开发微信小程序
查看>>
谁说数据库防火墙风险大?可能你还不知道应用关联防护
查看>>
ASP.NET Core应用针对静态文件请求的处理[2]: 条件请求与区间请求
查看>>
怎样做一个企业?尤其是在这个互联网时代
查看>>
DVNA:Node.js打造的开源攻防平台
查看>>
17个案例带你3分钟搞定Linux正则表达式
查看>>
Java 8 比较器:如何对 List 排序
查看>>
苹果是否步思科后尘折戟中国
查看>>
漏洞预警!微软曝光震网三代漏洞,隔离网面临重大危机
查看>>
协鑫集成第二批1000台E-KwBe光伏储能设备即将启运澳洲
查看>>
爱立信物联网广州路演
查看>>
云计算企业业绩分化明显 9家上市公司中期预喜
查看>>
《VMware Virtual SAN权威指南(原书第2版)》一3.5 可能发生的网络配置问题
查看>>
SK电讯发布Q2财报 净利润同比下降26.9%
查看>>
零售品牌如何驾驭大数据主导商业决策?
查看>>
经济模式UPS在数据中心的应用(上)
查看>>