会做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的更多相关文章

  1. BZOJ2437 [Noi2011]兔兔与蛋蛋 【博弈论 + 二分图匹配】

    题目链接 BZOJ2437 题解 和JSOI2014很像 只不过这题动态删点 如果我们把空位置看做\(X\)的话,就会发现我们走的路径是一个\(OX\)交错的路径 然后将图二分染色,当前点必胜,当且仅 ...

  2. 【BZOJ2437】【NOI2011】兔兔与蛋蛋(博弈论,二分图匹配)

    [BZOJ2437][NOI2011]兔兔与蛋蛋(博弈论,二分图匹配) 题面 BZOJ 题解 考虑一下暴力吧. 对于每个状态,无非就是要考虑它是否是必胜状态 这个直接用\(dfs\)爆搜即可. 这样子 ...

  3. BZOJ2437 NOI2011兔兔与蛋蛋(二分图匹配+博弈)

    首先将棋盘黑白染色,不妨令空格处为黑色.那么移动奇数次后空格一定处于白色格子,偶数次后空格一定处于黑色格子.所以若有某个格子的棋子颜色与棋盘颜色不同,这个棋子就是没有用的.并且空格与某棋子交换后,棋子 ...

  4. bzoj2437 [Noi2011]兔兔与蛋蛋

    二分图博弈果然都是一个套路,必经点必胜,非必经点必败, 但是肯定不能每走一步就重新建图判断必胜还是必败,那么我们可以这样:每走一步就把这个点删掉,然后find他原来的匹配,如果找不到,就说明他是必经点 ...

  5. 【bzoj2437】[Noi2011]兔兔与蛋蛋 二分图最大匹配+博弈论

    Description Input 输入的第一行包含两个正整数 n.m. 接下来 n行描述初始棋盘.其中第i 行包含 m个字符,每个字符都是大写英文字母"X".大写英文字母&quo ...

  6. 【BZOJ2437】[Noi2011]兔兔与蛋蛋(博弈+二分图)

    传送门 题意: 给出一个\(n*m\)的棋盘,上面有若干个黑色棋子,若干个白色棋子,还有一个空格. 每次先手选择一个空格,将它与相邻的某个白色棋子交换:后手则选择一个空格,与相邻的某个黑色棋子交换. ...

随机推荐

  1. Opencv图像与矩阵的操作

    #include "stdafx.h" #include <cv.h> #include <cxcore.h> #include <highgui.h ...

  2. 学习KnockOut第二篇之Counter

                                                                        学习KnockOut第二篇之Counter        欲看此 ...

  3. 瞧一瞧,看一看呐,用MVC+EF快速弄出一个CRUD,一行代码都不用写,真的一行代码都不用写!!!!

    瞧一瞧,看一看呐用MVC+EF快速弄出一个CRUD,一行代码都不用写,真的一行代码都不用写!!!! 现在要写的呢就是,用MVC和EF弄出一个CRUD四个页面和一个列表页面的一个快速DEMO,当然是在不 ...

  4. Ruby 语法快速入门

    作用域:指的是类,模块,方法 常量:无需指定类型,全大写 FANS = 100 puts "We have" + FANS.to_s + "fans" 变量 局 ...

  5. win8 telnet VirtualBox中的redhat9

    1. VirtualBox设置网络连接为“桥接网卡”,并且此网卡要为win8正在使用的网卡(比如我的电脑上使用的就是无线网卡,则选择网卡时也要用无线网卡) 2. 在redhat的终端里,运行ifcon ...

  6. 1502: [NOI2005]月下柠檬树 - BZOJ

    Description Input 文件的第1行包含一个整数n和一个实数alpha,表示柠檬树的层数和月亮的光线与地面夹角(单位为弧度).第2行包含n+1个实数h0,h1,h2,…,hn,表示树离地的 ...

  7. SVN--下载、安装VisualSVN server 服务端和 TortoiseSVN客户端

    前言: 在http://www.cnblogs.com/xiaobaihome/archive/2012/03/20/2407610.html的博客中已经很详细地介绍了SVN的服务器--VisualS ...

  8. 输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空)

    // test20.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<iostream> #include< ...

  9. Matlab中cell2mat的使用

    binIndices是1*50的cell,每个cell是的1*n(n不定),那么cell2mat(binIndices)得到的是1*sum(cellfun(@length,binIndices))的行 ...

  10. 【转载】C++针对ini配置文件读写大全

    http://blog.csdn.net/hgy413/article/details/6666374# ini文件(Initialization file),这种类型的文件中通常存放的是一个程序的初 ...