uva1560
In an extended version of the game Lights Out®, is a puzzle with 5 rows of 6 buttons each (the actual puzzle has 5 rows of 5 buttons each). Each button has a light. When a button is pressed, that button and each of its (up to four) neighbors above, below, right and left, has the state of its light reversed. (If on, the light is turned off; if off, the light is turned on.) Buttons in the corners change the state of 3 buttons; buttons on an edge change the state of 4 buttons and other buttons change the state of 5. For example, if the buttons marked ‘×’ on the left below were to be pressed, the display would change to the image on the right. The aim of the game is, starting from any initial set of lights on in the display, to press buttons to get the display to a state where all lights are off. When adjacent buttons are pressed, the action of one button can undo the effect of another. For instance, in the display below, pressing buttons marked ‘×’ in the left display results in the right display. Note that the buttons in row 2 column 3 and row 2 column 5 both change the state of the button in row 2 column 4, so that, in the end, its state is unchanged. Note: 1. It does not matter what order the buttons are pressed. 2. If a button is pressed a second time, it exactly cancels the effect of the first press, so no button ever need be pressed more than once. 3. As illustrated in the second diagram, all the lights in the first row may be turned off, by pressing the corresponding buttons in the second row. By repeating this process in each row, all the lights in the first four rows may be turned out. Similarly, by pressing buttons in columns 2, 3 …, all lights in the first 5 columns may be turned off. Write a program to solve the puzzle. Input The first line of the input is a positive integer n which is the number of puzzles that follow. Each puzzle will be five lines, each of which has six ‘0’s or ‘1’s separated by one or more spaces. A ‘0’ indicates that the light is off, while a ‘1’ indicates that the light is on initially. Output For each puzzle, the output consists of a line with the string: ‘PUZZLE #m’, where m is the index of the puzzle in the input file. Following that line, is a puzzle-like display (in the same format as the input). In this case, ‘1’s indicate buttons that must be pressed to solve the puzzle, while ‘0’s indicate buttons, which are not pressed. There should be exactly one space between each ‘0’ or ‘1’ in the output puzzle-like display. Sample Input 2 0 1 1 0 1 0 1 0 0 1 1 1 0 0 1 0 0 1 1 0 0 1 0 1 0 1 1 1 0 0 0 0 1 0 1 0 1 0 1 0 1 1 0 0 1 0 1 1 1 0 1 1 0 0 0 1 0 1 0 0 Sample Ouput PUZZLE #1 1 0 1 0 0 1 1 1 0 1 0 1 0 0 1 0 1 1 1 0 0 1 0 0 0 1 0 0 0 0 PUZZLE #2 1 0 0 1 1 1 1 1 0 0 0 0 0 0 0 1 0 0 1 1 0 1 0 1 1 0 1 1 0 1
高斯消元xor。。。
保证有解了,那么直接消元,就可以了
#include<bits/stdc++.h>
using namespace std;
const int N = ;
const int dx[] = {-, , , }, dy[] = {, , -, };
#define id(i, j) (i - 1) * 6 + j
int a[N + ][N + ];
void build()
{
memset(a, , sizeof(a));
for(int i = ; i <= ; ++i)
for(int j = ; j <= ; ++j)
for(int k = ; k < ; ++k)
{
int x = i + dx[k], y = j + dy[k];
if(x > && x <= && y > && y <= ) a[id(i, j)][id(x, y)] = a[id(x, y)][id(i, j)] = ;
}
}
void gauss_jordan()
{
for(int now = ; now <= N; ++now)
{
int x = ;
for(int i = now; i <= N; ++i) if(a[i][now] == ) { x = i; break; }
if(!x) continue;
for(int i = ; i <= N + ; ++i) swap(a[now][i], a[x][i]);
for(int i = ; i <= N; ++i) if(i != now && a[i][now])
for(int j = ; j <= N + ; ++j) a[i][j] ^= a[now][j];
}
}
int main()
{
int T; scanf("%d", &T);
for(int kase = ; kase <= T; ++kase)
{
build();
for(int i = ; i <= N; ++i) scanf("%d", &a[i][N + ]), a[i][i] = ;
gauss_jordan();
printf("PUZZLE #%d\n", kase);
for(int i = ; i <= ; ++i)
{
for(int j = ; j < ; ++j) printf("%d ", a[(i - ) * + j][N + ]);
printf("%d\n", a[i * ][N + ]);
}
}
return ;
}
uva1560的更多相关文章
随机推荐
- 10.Spring Bean的生命周期
Spring IOC容器可以管理Bean的生命周期,允许在Bean声明周期的特定点执行定制的任务. Spring IOC容器对Bean的生命周期进行管理的过程. 1.通过构造器或工厂方法创建Bean实 ...
- rbac组件之权限操作(四)
对于权限表的操作有两种方式,第一种是一个个的权限进行curd,另外一种是批量操作,自动发现django程序中的路由,进行批量curd,首先介绍第一种方式. 因为在列出菜单时,已经将权限列表列出来了,所 ...
- [转] angular2-highcharts用法详解
1. 使用npm安装angular2-highcharts npm install angular2-highcharts --save 2.主模块中引入 app.module.ts import { ...
- 全文搜索(A)-相关性
文章:搜索相关性 文章:推荐系统中相似度算法介绍及效果测试 文章:常用的相似度计算方法原理及实现 文章:推荐系统用户相似度计算方法研究
- struts面试题及答案【重要】
1. 简述 Struts2 的工作流程: ①. 请求发送给 StrutsPrepareAndExecuteFilter ②. StrutsPrepareAndExecuteFilter 判定该请求是否 ...
- HDU 5641 King's Phone【模拟】
题意: 给定一串密码, 判断是否合法. 长度不小于4 不能重复经过任何点 不能跳过中间点,除非中间点已经经过一次. 分析: 3*3直接记录出可能出现在两点之间的点,直接模拟就好. 注意审题,别漏了判断 ...
- openFileOutput 文件属性设置、主动配置文件的可读写属性及事实上现方式
首先參考 Android 内部存储相关的函数(getCacheDir,getDir, getFileStreamPath,getFilesDir,openFileInput, ...) 1. 用ope ...
- 【python】glob模块、os模块
http://www.cnblogs.com/hongten/p/hongten_python_glob.html http://wenku.baidu.com/link?url=AgUq9_yQVj ...
- Elasticsearch学习系列之介绍安装
前言 关于ELK搭建的问题,或许你还有些模糊,其实你把我视频里讲的知识点串联起来就明白了.搭建ELK环境,看下面我说的: 首先,先把ES集群搭建起来,建议用CentOS6.5 64位的linux系统, ...
- cakephp2.3.8中何为component
大胆假设,小心求证 记得这句话是以前读高三的时候,一个数学老师(圆头,有点胖胖的老师,不是很记得),经常挂在嘴边的一句话, 对于我们不理解,或者说是无法确定的东西,我们不妨先大胆地去假 ...