BZOJ 1443 [JSOI2009]游戏Game ——博弈论
好题。
首先看到棋盘,先黑白染色。
然后就是二分图的经典模型。
考虑最特殊的情况,完美匹配,那么先手必胜,
因为无论如何,先手走匹配边,后手无论走哪条边,总有对应的匹配边。
如果在不在最大匹配中出发,先手无论如何会走到最大匹配中,然后后手顺着匹配走,一定能胜利。
(万一又走到非最大匹配中呢,显然这样我们会找到一条增广路,与最大匹配不符)。
但是最大匹配不止又一种,所以我们需要判断是否在最大匹配中,需要寻找交错路。
如果在最大匹配中出发,显然先手必胜,(如果走到非最大匹配的点上,那么就相当于找到一条交错路可以替换,反而让非最大匹配换到了最大匹配中)
然后就相当于求一定不在最大匹配中的点了。
#include <vector>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std; #define F(i,j,k) for (int i=j;i<=k;++i)
#define D(i,j,k) for (int i=j;i>=k;--i) int mov[4][2]={{0,1},{1,0},{-1,0},{0,-1}};
vector <int> v[10005];
int id[105][105],a[105][105],n,m,cnt,vis[10005],linker[10005];
char s[105];
int ans[10005][2],tot=0,g[10005][10]; int dfs(int x)
{
for (int i=1;i<=g[x][0];++i)
{
int t=g[x][i];
if (vis[t]) continue;
vis[t]=1;
if (!linker[t]||dfs(linker[t]))
{
linker[t]=x;
linker[x]=t;
return 1;
}
}
return 0;
} int main()
{
int n,m;
scanf("%d%d",&n,&m);
F(i,1,n) F(j,1,m) id[i][j]=++cnt;
F(i,1,n)
{
scanf("%s",s+1);
F(j,1,m)
if (s[j]=='#') a[i][j]=1;
}
F(i,1,n) F(j,1,m)
if (!a[i][j]&&((i+j)%2)){
int tx,ty;
F(k,0,3)
{
tx=i+mov[k][0];ty=j+mov[k][1];
if (tx>=1&&tx<=n&&ty>=1&&ty<=m&&!a[tx][ty])
{
g[id[i][j]][++g[id[i][j]][0]]=id[tx][ty];
g[id[tx][ty]][++g[id[tx][ty]][0]]=id[i][j];
}
}
}
int cnt=0;
F(i,1,n) F(j,1,m) if (!a[i][j]&&(i+j)%2)
{
memset(vis,0,sizeof vis);
if (dfs(id[i][j])) cnt++;
}
F(i,1,n) F(j,1,m) if (!a[i][j])
{
memset(vis,0,sizeof vis);
vis[id[i][j]]=1;
if (!linker[id[i][j]]||dfs(linker[id[i][j]]))
{
tot++;
ans[tot][0]=i;ans[tot][1]=j;
linker[id[i][j]]=0;
}
}
if (!tot) printf("LOSE\n");
else
{
printf("WIN\n");
F(i,1,tot) printf("%d %d\n",ans[i][0],ans[i][1]);
}
}
BZOJ 1443 [JSOI2009]游戏Game ——博弈论的更多相关文章
- BZOJ:1443: [JSOI2009]游戏Game
原题链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1443 反正不看题解我是完全想不出系列…… 先把棋盘黑白染色,也就是同一对角线上颜色相同,使 ...
- BZOJ.1443.[JSOI2009]游戏Game(二分图博弈 匈牙利)
题目链接 \(Description\) 一个\(N*M\)的有障碍的棋盘,先手放置棋子后,从后手开始轮流移动棋子,不能走重复的位置,不能移动的输.求在哪些位置放棋子是先手必胜的. \(Solutio ...
- 【BZOJ】1443: [JSOI2009]游戏Game
[算法]博弈论+二分图匹配(最大流) [题解]方格图黑白染色得到二分图, 二分图博弈:当起点不属于某个最大匹配时,后手必胜. 问题转化为那些点不属于某个最大匹配. 先找到一个最大匹配,非匹配点加入答案 ...
- BZOJ:[JSOI2009]游戏Game【二分图匹配乱搞】
题目大意:n*m的棋盘,其中有些区域是禁区,两个人在棋盘上进行博弈,后手选择棋子的初始位置,然后先后手轮流将棋子往上下左右移动,走过的区域不能再走,问能否有一个位置使得后手必胜 Input 输入数据首 ...
- BZOJ1443: [JSOI2009]游戏Game
如果没有不能走的格子的话,和BZOJ2463一样,直接判断是否能二分图匹配 现在有了一些不能走的格子 黑白染色后求出最大匹配 如果是完备匹配,则无论如何后手都能转移到1*2的另一端,故先手必输 否则的 ...
- JSOI2009 游戏
1443: [JSOI2009]游戏Game Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 557 Solved: 251[Submit][Stat ...
- BZOJ 1444:[JSOI2009]有趣的游戏
BZOJ 1444:[JSOI2009]有趣的游戏 题目链接 首先我们建出Trie图,然后高斯消元. 我们设\(f_i\)表示经过第\(i\)个点的期望次数: \[ f_x=\sum i\cdot p ...
- 【BZOJ1022】小约翰的游戏(博弈论)
[BZOJ1022]小约翰的游戏(博弈论) 题面 BZOJ 题解 \(Anti-SG\)游戏的模板题目. #include<iostream> #include<cstdio> ...
- 【BZOJ1188】分裂游戏(博弈论)
[BZOJ1188]分裂游戏(博弈论) 题面 BZOJ 洛谷 题解 这道题目比较神仙. 首先观察结束状态,即\(P\)状态,此时必定是所有的豆子都在最后一个瓶子中. 发现每次的转移一定是拿出一棵豆子, ...
随机推荐
- ssh框架出现Java.lang.NoSuchMethodError: antlr.collections.AST.getLine()I错误
原因:因为Struts自带的antlr-2.7.2.jar,比Hibernate自带的antlr-2.7.7.jar的版本要低,存在jar包冲突现象,因此要删除前一个低版本的. 由于myeclipse ...
- TitleBar(标题栏)的使用
github地址:https://github.com/buhuiming/BHMAndroid 使用compile 'com.bhm.sdk.bhmlibrary:BHMLibrary:1.1.2' ...
- 如何通过Xcode 5中集成的XCTest框架进行简单的单元测试
XCTest 1.第一个单元测试 XCTest是Xcode 5中自带的测试框架 下面从一个Demo开始.首先用Xcode新建一个工程UnitTestDemo,工程目录结构如下: 可以看到工程下面多了一 ...
- Android学习总结(五)———— BroadcastReceiver(广播接收器)的基本概念和两种注册广播方式
我们学完了Android四大组件的Activity和Service了,接下来我们一起来学习Android四大组件的第三个吧:BroadcastReceiver(广播接收者),计划如下图: 一.Broa ...
- 换个语言学一下 Golang (5)——运算符
运算符用于在程序运行时执行数学或逻辑运算. Go 语言内置的运算符有: 算术运算符 关系运算符 逻辑运算符 位运算符 赋值运算符 其他运算符 接下来让我们来详细看看各个运算符的介绍. 算术运算符 下表 ...
- 油猴Tampermonkey 全局函数 它的注入函数都在 onload里面,直接写函数 都是内部函数,外部要是调用,就要挂靠到window上
油猴Tampermonkey 全局函数 它的注入函数都在 onload里面,直接写函数 都是内部函数,外部要是调用,就要挂靠到window上 window.like111 = function (){ ...
- java导入Excel表格数据
首先导入Excel数据需要几样东西 第一需要两个依赖包,这里直接是在pom注入依赖 <!--excel--> <dependency> <groupId>org.a ...
- Java第十二次作业:什么是一维数组?什么是对象数组?吃金币游戏2.0版 新增炸弹功能 新增游戏倒计时功能 新增胜利失败检测功能 使用如鹏游戏引擎制作窗体 一维数组设置金币
什么是数组? 数组的定义:是用统一的名字代表这批数据,用序号来区分各个数据.数组是无序的数据元素按有序的下标组成的集合,分配固定空间大小的一种容器. 如何理解:其实就是一个同时放很多数据的变量. a= ...
- (59)zabbix拓扑图展示链路状况Link indicators
Link indicators介绍 上一篇已经了解了如何配置zabbix map,也提到了如何连接两个map元素,这节我们来讲两个map元素之间的链路指示配置. 我们需要在链路上配置trigger,如 ...
- GIMP的Path的合并于复制
1/Path的复制不能像图层一样简单的复制粘贴,只有通过merge的方法实现: 使要合并的Path处于可见状态,右击Path工具栏: 合并前与合并后比较: 2/向不同文件复制Path: 到另外一个 ...