bzoj2437
会做jsoi那道game,这题就非常简单了吧
我们考虑空格的移动,显然,初始与空格位置距离为奇数的黑棋和距离为偶数的白棋并没有什么用,
空格不会移到那,我们直接把他们当作障碍,其他点我们当作可移动区域
这不就和game那道题一样了吗,只不过这题不问棋子放哪
而是给定棋子位置,问当前是否是先手必胜
(错误操作就是指当前是先手必胜而移动一格还是先手必胜的操作)
我们对图重新黑白染色,做二分图匹配,显然,棋子在一定能被匹配的点上时,是先手必胜
证明类似game,因为棋子在一定在一定能被匹配的点上,我们第一步走向匹配点
下一步对方要么不能走,要么走一条非匹配边,那所到达的点,一定是匹配了的
否则,一开始的点就不一定在匹配,与假设矛盾,所以最后走的一条边一定是匹配边得证
至于怎么找一定能被匹配的点,我们做完二分图匹配后,如果这个点匹配了,那么我们删掉这个点,从这个点配对的点出发看是否能找到增广路即可
const dx:array[..] of longint=(,,,-);
dy:array[..] of longint=(,-,,); type node=record
po,next:longint;
end; var e:array[..] of node;
v:array[..] of boolean;
b:array[..,..] of longint;
a:array[..,..] of char;
mat,p,c:array[..] of longint;
t,xx,yy,i,n,m,j,k,len,x,y,ans:longint;
f1,f2:boolean; procedure add(x,y:longint);
begin
inc(len);
e[len].po:=y;
e[len].next:=p[x];
p[x]:=len;
end; function dfs(x:longint):boolean;
var i,y:longint;
begin
v[x]:=true;
i:=p[x];
while i<> do
begin
y:=e[i].po;
if not v[y] and (mat[y]<>-) then
begin
v[y]:=true;
if (mat[y]=) or dfs(mat[y]) then
begin
mat[y]:=x;
mat[x]:=y;
exit(true);
end;
end;
i:=e[i].next;
end;
exit(false);
end; function check:boolean;
var j,k:longint;
begin
k:=b[x,y];
j:=mat[k];
mat[j]:=;
mat[k]:=-;
if j= then exit(false)
else begin
fillchar(v,sizeof(v),false);
exit(not dfs(j));
end;
end; begin
readln(n,m);
for i:= to n do
begin
for j:= to m do
begin
read(a[i,j]);
if a[i,j]='.' then
begin
x:=i;
y:=j;
a[i,j]:='X';
end;
end;
readln;
end;
for i:= to n do
for j:= to m do
if (a[i,j]='O') xor ((abs(i-x)+abs(j-y)) mod =) then
begin
inc(t);
b[i,j]:=t;
end; for i:= to n do
for j:= to m do
if b[i,j]> then
begin
for k:= to do
begin
xx:=i+dx[k];
yy:=j+dy[k];
if b[xx,yy]> then add(b[i,j],b[xx,yy]);
end;
end; for i:= to t do
if mat[i]= then
begin
fillchar(v,sizeof(v),false);
dfs(i);
end; readln(k);
for i:= to k do
begin
f1:=check;
readln(x,y);
f2:=check;
if f1 and f2 then
begin
inc(ans);
c[ans]:=i;
end;
readln(x,y);
end;
writeln(ans);
for i:= to ans do
writeln(c[i]);
end.
bzoj2437的更多相关文章
- BZOJ2437 [Noi2011]兔兔与蛋蛋 【博弈论 + 二分图匹配】
题目链接 BZOJ2437 题解 和JSOI2014很像 只不过这题动态删点 如果我们把空位置看做\(X\)的话,就会发现我们走的路径是一个\(OX\)交错的路径 然后将图二分染色,当前点必胜,当且仅 ...
- 【BZOJ2437】【NOI2011】兔兔与蛋蛋(博弈论,二分图匹配)
[BZOJ2437][NOI2011]兔兔与蛋蛋(博弈论,二分图匹配) 题面 BZOJ 题解 考虑一下暴力吧. 对于每个状态,无非就是要考虑它是否是必胜状态 这个直接用\(dfs\)爆搜即可. 这样子 ...
- BZOJ2437 NOI2011兔兔与蛋蛋(二分图匹配+博弈)
首先将棋盘黑白染色,不妨令空格处为黑色.那么移动奇数次后空格一定处于白色格子,偶数次后空格一定处于黑色格子.所以若有某个格子的棋子颜色与棋盘颜色不同,这个棋子就是没有用的.并且空格与某棋子交换后,棋子 ...
- bzoj2437 [Noi2011]兔兔与蛋蛋
二分图博弈果然都是一个套路,必经点必胜,非必经点必败, 但是肯定不能每走一步就重新建图判断必胜还是必败,那么我们可以这样:每走一步就把这个点删掉,然后find他原来的匹配,如果找不到,就说明他是必经点 ...
- 【bzoj2437】[Noi2011]兔兔与蛋蛋 二分图最大匹配+博弈论
Description Input 输入的第一行包含两个正整数 n.m. 接下来 n行描述初始棋盘.其中第i 行包含 m个字符,每个字符都是大写英文字母"X".大写英文字母&quo ...
- 【BZOJ2437】[Noi2011]兔兔与蛋蛋(博弈+二分图)
传送门 题意: 给出一个\(n*m\)的棋盘,上面有若干个黑色棋子,若干个白色棋子,还有一个空格. 每次先手选择一个空格,将它与相邻的某个白色棋子交换:后手则选择一个空格,与相邻的某个黑色棋子交换. ...
随机推荐
- Notes of the scrum meeting(2013/10/20)
软工项目组buaa_smile确定自由项目主题及实现功能的scrum meeting meeting time:7:30~9:00p.m.,October 20th,2013 meeting plac ...
- 两行代码搞定UITableView无数据无网络显示-b
不知是否有像我一样的,每次写TableView在监听网络和无数据源时逻辑处理提示视图都是一堆代码,很繁琐也很重复的垃圾代码(可能就只有我这样
- PHP的会话处理函数session
(๑•ᴗ•๑) PHP Session 变量 当运行一个应用程序时,你会打开它,做些更改,然后关闭它.这很像一次会话.计算机清楚你是谁.它知道你何时启动应用程序,并在何时终止.但是在因特网上,存在一个 ...
- C# type - IsPrimitive
Type t = typeof(string); if (t.IsPrimitive)//not { Console.WriteLine("string is a Primitive&quo ...
- javascript 获取父页面中元素对象方法
父页面中: <input type="hidden" id="areaID" value="test1"> <iframe ...
- 【转载】Spring中的applicationContext.xml与SpringMVC的xxx-servlet.xml的区别
一直搞不明白两者的区别. 如果使用了SpringMVC,事实上,bean的配置完全可以在xxx-servlet.xml中进行配置.为什么需要applicationContext.xml?一定必须? 一 ...
- 剑指offer--面试题13
题目:以O(1)的时间复杂度删除单链表中的某个节点 自己所写代码如下: //以O(1)时间删除链表节点 //要求:单向链表,头指针,待删节点指针 //链表节点 struct ListNode { in ...
- 使用EF code first和asp.net mvc4遇到的问题总结
最近使用EF code first和asp.net mvc4做项目,遇到些问题,记录一下. 一.EF code first 生成外键列问题. 一般情况下,都是先写一个int型外键id属性,然后写一个外 ...
- Open Phone, SMS, Email, Skype and Browser apps of Android in Unity3d
最近项目需要使用Android的一些基本功能,写插件各种悲剧,google了一下,如获至宝.Nice ! string url = String.Format("tel:{0}", ...
- PHPStorm 3.0 与服务器端代码同步配置
首先打开PhpStrom->Toolbar->Settings(工具栏的倒数第三行) 进入Settings后的界面如下 单击进入左边Deployment目录,在右边配置信息里面进行配置 填 ...