【BZOJ-3895】取石子 记忆化搜索 + 博弈
3895: 取石子
Time Limit: 1 Sec Memory Limit: 512 MB
Submit: 263 Solved: 127
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
3
1 1 2
2
3 4
3
2 3 5
Sample Output
NO
NO
HINT
Source
Solution
结论+记忆化搜索
首先,手玩或者感受一下,很好发现:操作总数S=$\sum a_{i}+N-1.......(x>1)$
这样进一步发现,如果S为奇数,显然先手必胜
证明:
难以证明S为奇数先手必胜,考虑证明S为偶数先手必败;
首先如果只有一堆,为奇数,显然先手必胜;
1.如果先手选择合并两堆石子,那么每堆石子的个数依然大于1,x变为奇数.
2.如果先手选择从一堆石子数大于2的堆中拿走一枚石子,那么同上每堆石子个数依然大于1,x变为奇数。
3.如果先手选择从一堆石子数等于2的堆中拿走一枚石子,那么后手可以合并剩下的1枚石子到任意一个堆。那样x的奇偶性不变,每堆石子的个数依然大于
所以这样可以得到对于所有x>1的情况,那么考虑存在x=1的情况
可以分为4种情况考虑:
1.取走某个大小为1的堆中的石子.
2.将某个大小为1的堆和某个大小不为1的堆合并
3.合并两个大小为1的堆.
4.对大小不为1的堆进行合并或者取石子操作.
那么我们用OK[i][j]表示状态,表示仅有1颗石子的有i堆,多颗石子堆的总操作数为S
那么对于上述情况,显然可以利用记忆化搜索转移
考虑数据最大值并不大,所以可以通过所有数据。
Code
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
inline int read()
{
int w=; char ch=getchar();
while (ch<'' || ch>'') ch=getchar();
while (ch>='' && ch<='') w=w*+ch-'',ch=getchar();
return w;
}
#define MAXN 100
#define int register int
bool ok[][],visit[][];
inline bool DFS(int x,int y)
{
if (!x) return y&;
if (y==) return DFS(x+,);
if (visit[x][y]) return ok[x][y];
visit[x][y]=;
if (x>= && y && !DFS(x-,y+)) {ok[x][y]=; return ;}
if (x>= && !y && !DFS(x-,y+)) {ok[x][y]=; return ;}
if (x && y && !DFS(x-,y+)) {ok[x][y]=; return ;}
if (y && !DFS(x,y-)) {ok[x][y]=; return ;}
if (x && !DFS(x-,y)) {ok[x][y]=; return ;}
ok[x][y]=;
return ;
}
main()
{
int N,a[MAXN],T,sum;
T=read();
while (T--)
{
N=read();
bool flag=;
sum=;
for (int i=; i<=N; i++)
{
a[i]=read(),sum+=a[i];
if (a[i]==) flag=;
}
if (flag)
if ((sum+N-)&) puts("YES"); else puts("NO");
else
{
int x=,y=;
for (int i=; i<=N; i++)
if (a[i]==) x+=a[i]; else y+=a[i]+;
if (DFS(x,max(y-,))) puts("YES"); else puts("NO");
}
}
// return 0;
}
Sunshine学长的Day3T2....
测试的时候,手玩了好几组,发现了结论,于是随口和DCrusher大爷一说
被DCrusher大爷一顿教育
大爷教育我说,随便一个记搜就出来了,然后滚去用10分钟写了个记搜..
手残写错了一个地方,卡成了80.....BeiYu大爷标算卡成50...
DCrusher实力虐场Orz
【BZOJ-3895】取石子 记忆化搜索 + 博弈的更多相关文章
- BZOJ 3895: 取石子[SG函数 搜索]
有N堆石子 ·从某堆石子中取走一个 ·合并任意两堆石子 不能操作的人输. 100%的数据满足T<=100, N<=50. ai<=1000 容易发现基础操作数$d=\sum a ...
- HDU 4597 Play Game (记忆化搜索博弈DP)
题意 给出2*n个数,分两列放置,每列n个,现在alice和bob两个人依次从任意一列的对头或队尾哪一个数,alice先拿,且两个人都想拿最多,问alice最后能拿到数字总和的最大值是多少. 思路 4 ...
- BZOJ.1024.[SCOI2009]生日快乐(记忆化搜索)
题目链接 搜索,枚举切的n-1刀. 对于长n宽m要切x刀,可以划分为若干个 长n'宽m'要切x'刀 的子问题,对所有子问题的答案取max 对所有子问题的方案取min 就是当前状态答案. 这显然是会有很 ...
- bzoj 3895 取石子 —— 博弈论
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3895 看了博客:https://blog.csdn.net/popoqqq/article/ ...
- bzoj 3895: 取石子
$ \color{#0066ff}{ 题目描述 }$ Alice和Bob两个好朋含友又开始玩取石子了.游戏开始时,有N堆石子 排成一排,然后他们轮流操作(Alice先手),每次操作时从下面的规则中任选 ...
- bzoj 3895 取石子——博弈论
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3895 看题解:https://blog.csdn.net/popoqqq/article/d ...
- bzoj 1415 期望dp + 记忆化搜索
思路:这个题看着感觉不能dp,其实是可以dp的,因为狼每次走两步,兔子每次走一步,每进行一轮以后,狼和兔子的距离 肯定是在接近的,没有相同的状态,dp之前预处理出来,每一步狼该往哪里走. #inclu ...
- HDU 4597 记忆化搜索
² 博弈取牌—记忆化搜索 题目描述: 有两副带有数字的牌,(数字>0)两人轮流取,取中了某张牌,自己的分数就加上牌上的数字,但只能从两端取,每人都会用最优的策略使得自己的分数最高.问A先取,他能 ...
- UVALive 6470 Chomp --记忆化搜索
题意:给一个只有三行的方块阵(横向最多100个),然后p,q,r分别代表第1,2,3层的方格数,两人轮流去掉一个格子,此时这个格子的右上方都会被去掉,面临只剩最左下角的一个格子的状态的人输,问先手能否 ...
随机推荐
- Linux收集
1.rsync快速删除文件 rsync --delete -avH /empty /rmdir 选项说明: –delete-before 接收者在传输之前进行删除操作 –progress 在传输时显示 ...
- Smoothing in fMRI analysis (FAQ)
Source: http://mindhive.mit.edu/node/112 1. What is smoothing? "Smoothing" is generally us ...
- 李学斌:论复杂系统中的应用间协作V3
说明 本文主要讨论了巨型复杂业务系统的一种构建思路,力图实现决策意志的快速.准确.一致的下传并简化实施成本提供实施效率.通过全业务领域的即时流程编排,实现全网业务IT系统的快速建设与迭代.本文所讲的方 ...
- 【福吧资源网整理】老男孩-python运维6期 不加密
老男孩-python运维6期 不加密,连夜整理出来分享给大家老男孩的python教程确实不错. 教程目录: 下载地址:http://www.fu83.cn/thread-204-1-1.html
- canvas drag 实现拖拽拼图小游戏
博主一直心心念念想做一个小游戏- 前端时间终于做了一个小游戏,直到现在才来总结,哈哈- 以后要勤奋点更新博客! 实现原理 1.如何切图? 用之前的方法就是使用photoshop将图片切成相应大小的图 ...
- 两个Canvas小游戏
或许连小游戏都算不上,可以叫做mini游戏. 没有任何框架或者稍微有点深度的东西,所以有js基础的或者要追求炫酷效果的可以直接ctrl+w了. 先贴出两个游戏的试玩地址: 是男人就走30步 是男人就忍 ...
- github开源:企业级应用快速开发框架CIIP WEB+WIN+移动端
简介 CIIP是基于XAF开发的开源信息系统框架.CIIP最常见的应用场景是基于数据库的企业级应用程序,例如供应链系统,ERP系统,MRP系统,CRM系统等. CIIP支持WEB版本.Windows桌 ...
- C#读取网络流,读取网络上的js文件
写博客的目的就是让其他人少走弯路. C#读取网络上的流和js文件出现的问题 一开始看了今天博客园上的推荐文章,用C#+HtmlAgilityPack+XPath带你采集数据(以采集天气数据为例子),然 ...
- C#:异步编程和线程的使用(.NET 4.5 )
摘自:http://www.codeproject.com/Articles/996857/Asynchronous-programming-and-Threading-in-Csharp-N(葡萄城 ...
- window 运行指令(1)
添加或删除程序 appwiz.cpl 管理工具 control admintools Bluetooth文件传送向导 fsquirt 计算器 calc 证书管理控制台 certmgr.msc 字符映射 ...