【高斯消元】【异或方程组】poj1222 EXTENDED LIGHTS OUT

由于每个点的状态受到其自身和周围四个点的影响,所以可以这样建立异或方程组:

引用题解:

http://hi.baidu.com/ofeitian/item/9899edce6dc6d3d297445264

题目大意:给你一个5*6的矩阵,矩阵里每一个单元都有一个灯和一个开关,如果按下此开关,那么开关所在位置的那个灯和开关前后左右的灯的状态都会改变(即由亮到不亮或由不亮到亮)。给你一个初始的灯的状态,问怎样控制每一个开关使得所有的灯最后全部熄灭(此题保证有唯一解)。

解题思路:高斯消元。很显然每个灯最多只需要按1下(因为按两下和没有按是一个效果)。我们可以定义30和未知数x0、x1.......x29代表每一个位置的开关是否被按。那么对于每一个灯的状态可以列一个方程,假设位置(i,j)处的开关为x(i*6+j),那么我们就可以列出方程:
x(i*6+j)+x((i-1)*6+j)+x((i+1)*6+j)+x(i*6+j-1)+x(i*6+j+1) = bo(mod 2)
(括号里的数字为x的下标,这里假设这些下标都是符合要求的,即都在矩形内,如果不在则可以去掉,当这个灯初始时是开着的,那么bo为1,否则为0)
这样可以列出30个方程,然后用高斯消元解这个方程组即可。

#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
#define N 31
const int dx[]={0,-1,0,1},dy[]={-1,0,1,0},n=30;
bool b[N],x[N],B[N][N+1],A[N][N+1];
int T,id[7][8];
void Madoka()
{
	memcpy(B,A,sizeof(A));
	for(int i=1;i<=n;++i)
	  B[i][n+1]=b[i];
	for(int i=1;i<=n;++i)
	  {
	  	int j=i;
	  	for(;j<=n;++j)
	  	  if(B[j][i])
	  	    break;
	  	swap(B[j],B[i]);
	  	for(int j=1;j<=n;++j)
	  	  if(j!=i&&B[j][i])
	  	    for(int k=1;k<=n+1;++k)
	  	      B[j][k]^=B[i][k];
	  }
	for(int i=1;i<=n;++i) x[i]=B[i][n+1];
}
int main()
{
	int pen=0;
	for(int i=1;i<=5;++i)
	  for(int j=1;j<=6;++j)
	    id[i][j]=++pen;
	scanf("%d",&T);
	for(int i=1;i<=T;++i)
	  {
	  	memset(A,0,sizeof(A));
	  	for(int j=1;j<=5;++j)
	  	  for(int k=1;k<=6;++k)
	  	    {
	  	      scanf("%d",&b[id[j][k]]);
	  	      A[id[j][k]][id[j][k]]=1;
	  	    }
	  	for(int j=1;j<=5;++j)
	  	  for(int k=1;k<=6;++k)
	  	    for(int l=0;l<4;++l)
	  	      if(id[j+dx[l]][k+dy[l]])
	  	        A[id[j][k]][id[j+dx[l]][k+dy[l]]]=1;
	  	Madoka();
	  	printf("PUZZLE #%d\n",i);
	  	for(int j=1;j<=5;++j)
	  	  {
	  	  	for(int k=1;k<6;++k)
	  	  	  printf("%d ",x[id[j][k]]);
	  	  	printf("%d\n",x[id[j][6]]);
	  	  }
	  }
	return 0;
}
时间: 2024-08-25 12:21:50

【高斯消元】【异或方程组】poj1222 EXTENDED LIGHTS OUT的相关文章

BZOJ.1923.[SDOI2010]外星千足虫(高斯消元 异或方程组 bitset)

题目链接 m个方程,n个未知量,求解异或方程组. 复杂度比较高,需要借助bitset压位. 感觉自己以前写的(异或)高斯消元是假的..而且黄学长的写法都不需要回代. //1100kb 324ms #include <cstdio> #include <cctype> #include <bitset> #include <algorithm> const int N=1004,M=2004; int n,m; char s[N]; std::bitset&l

UVA11542 Square(高斯消元 异或方程组)

建立方程组消元,结果为2 ^(自由变元的个数) - 1 采用高斯消元求矩阵的秩 #include<cstdio> #include<iostream> #include<cstdlib> #include<cstring> #include<string> #include<algorithm> #include<map> #include<queue> #include<vector> #incl

UVA 11542 Square 高斯消元 异或方程组求解

题目链接:点击打开链接 白书的例题练练手. . . P161 #include <cstdio> #include <iostream> #include <algorithm> #include <math.h> #include <string.h> #include <algorithm> using namespace std; #define ll int #define LL long long const int mod

poj1830(高斯消元解mod2方程组)

题目链接:http://poj.org/problem?id=1830 题意:中文题诶- 思路:高斯消元解 mod2 方程组 有 n 个变元,根据给出的条件列 n 个方程组,初始状态和终止状态不同的位置对应的方程右边常数项为1,状态相同的位置对于的方程组右边的常数项为0.然后用高斯消元解一下即可.若有唯一解输出1即可,要是存在 k 个变元,则答案为 1 << k, 因为每个变元都有01两种选择嘛- 代码: 1 #include <iostream> 2 #include <s

POJ 1222 EXTENDED LIGHTS OUT(高斯消元解XOR方程组)

http://poj.org/problem?id=1222 题意:现在有5*6的开关,1表示亮,0表示灭,按下一个开关后,它上下左右的灯泡会改变亮灭状态,要怎么按使得灯泡全部处于灭状态,输出方案,1表示按,0表示不按. 思路:每个开关最多只按一次,因为按了2次之后,就会抵消了. 可以从结果出发,也就是全灭状态怎么按能变成初始状态. 用3*3来举个例子,$X\left ( i,j \right )$表示这些开关是按还是不按,那么对于第一个开关,对它有影响的就只有2.4这两个开关,所以它的异或方程

bzoj2115 [Wc2011] Xor——高斯消元 &amp; 异或线性基

题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2115 异或两次同一段路径的权值,就相当于没有走这段路径: 由此可以得到启发,对于不同的走法,也许只需要找出一些东西,就可以把所有的走法用它们来异或表示出来: 再关注图上的环路,因为从 1 到 n 的不同路径也可以看作是经由 1 和 n 连接的环路,路径上也可能有环路: 发现对于环路的不同走法,就是把路与环的权值异或求最优值,重叠的部分异或了两次相当于不走: 于是问题转化为找出图上的所有环(

poj1753(高斯消元解mod2方程组)

题目链接:http://poj.org/problem?id=1753 题意:一个 4*4 的棋盘,初始时上面放满了黑色或白色的棋子.对 (i, j) 位置进行一次操作后 (i, j), (i + 1, j), (i - 1, j), (i, j + 1), (i, j - 1) 位置的棋子会变成原来相反的状态.问最少需要多少步可以将棋盘上的棋子全部变成白色或者黑色. 思路:分别将棋子变成黑色和白色,然后再用高斯消元解,其中步数较小者即为答案. 注意不存在唯一解时需要枚举自由变元来取得最小步数.

【高斯消元】BZOJ 1770: [Usaco2009 Nov]lights 燈

Description 貝希和她的閨密們在她們的牛棚中玩遊戲.但是天不從人願,突然,牛棚的電源跳閘了,所有的燈都被關閉了.貝希是一個很膽小的女生,在伸手不見拇指的無盡的黑暗中,她感到驚恐,痛苦與絕望.她希望您能夠幫幫她,把所有的燈都給重新開起來!她才能繼續快樂地跟她的閨密們繼續玩遊戲! 牛棚中一共有N(1 <= N <= 35)盞燈,編號為1到N.這些燈被置於一個非常複雜的網絡之中.有M(1 <= M <= 595)條很神奇的無向邊,每條邊連接兩盞燈. 每盞燈上面都帶有一個開關.當

POJ 2065 SETI(高斯消元解模方程组)

题目: SETI Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 1693   Accepted: 1054 Description For some years, quite a lot of work has been put into listening to electromagnetic radio signals received from space, in order to understand what

高斯消元与xor方程组

for(i=1;i<=n;i++) { for(j=i+1;j<=n;j++) if(a[j]>a[i]) swap(a[i],a[j]); if(!a[i]) break; for(j=60;j>=0;j--) if(a[i]>>j&1) { for(k=1;k<=n;k++) if(i!=k && (a[k]>>j&1)) a[k]^=a[i]; break; } } 对着这个代码思(dan)考(teng)了一星期.