The Pilots Brothers' refrigerator
Time Limit: 1000MS   Memory Limit: 65536K
Total Submissions: 22286   Accepted: 8603   Special Judge

Description

The game “The Pilots Brothers: following the stripy elephant” has a quest where a player needs to open a refrigerator.

There are 16 handles on the refrigerator door. Every handle can be in one of two states: open or closed. The refrigerator is open only when all handles are open. The handles are represented as a matrix 4х4. You can change the state of a handle in any location [i, j] (1 ≤ i, j ≤ 4). However, this also changes states of all handles in row i and all handles in column j.

The task is to determine the minimum number of handle switching necessary to open the refrigerator.

Input

The input contains four lines. Each of the four lines contains four characters describing the initial state of appropriate handles. A symbol “+” means that the handle is in closed state, whereas the symbol “−” means “open”. At least one of the handles is initially closed.

Output

The first line of the input contains N – the minimum number of switching. The rest N lines describe switching sequence. Each of the lines contains a row number and a column number of the matrix separated by one or more spaces. If there are several solutions, you may give any one of them.

Sample Input

-+--
----
----
-+--

Sample Output

6
1 1
1 3
1 4
4 1
4 3
4 4

Source

Northeastern Europe 2004, Western Subregion

题目大意

  给出$4\times 4$共$16$个门把手,改变一个门把手(打开或关闭)需要同时改变同行同列的门把手,当所有门把手都打开时才能打开门。+代表关,-代表开。

基本思路

  此题与POJ 1753差不太多,只是本题没有Impossible的情况,且需要输出改变的门把手的位置。POJ 1753的详细题解请看这里,里面讲的都可以用于此题。因此本文简要略过,只给出爆搜的代码,以及分治的详解。

  一、爆搜出奇迹:

  1、将16个门把手的状态压缩成一个整数。

  2、可以选择改变0个门把手(已经全开),1~16个门把手(重复选相当于没有改变),要求给出最小步数,因此从0搜到16即可。

  3、要求输出要改变的门把手的位置,在搜索中回溯即可。本题为特判,因此输出顺序没有关系。

  4、搜不到要把门把手的状态改回来再搜。

  代码如下:

 #include <stdio.h>

 int handle;

 void read() {
for(int i=; i<; i++) {
for(int j=; j<; j++) {
handle<<=;
if(getchar()=='-')
handle|=;
}
getchar();
}
} void change(int i, int j) {
handle^=0x000F<<(i<<);
handle^=0x1111<<j;
handle^=(0x1<<j)<<(i<<);
} bool check() {
return handle==0xFFFF;
} bool find(int n, int&k, int i, int j) {
if(n==) return check()&&printf("%d\n",k);
if(j==) ++i, j=;
for(; i<; i++) {
for(; j<; j++) {
change(i,j);
if(find(n-,k,i,j+)) {
printf("%d %d\n",-i,-j);
return true;
}
change(i,j);
}
j=;
}
return false;
} void work() {
for(int i=; i<=; i++)
if(find(i,i,,))
return;
} int main() {
read();
work();
return ;
}

POJ 2965 爆搜出奇迹

  二、“分治”?分治!

  1、网上有把这种方法叫做递推的,有叫做贪心的,其实都不太贴切。

  2、考虑一个小问题:若只想改变一个门把手的状态(打开或关闭),而不影响其他的门把手,在同行同列同时操作的规则下,要如何做到?答案是,我们把“同行同列都改变”的操作称为操作op,对于我们想要单独改变的那个门把手,不仅对它做一次操作op,还对它的同行同列的门把手都做一次操作op。注意改变偶数次还是原样,这样中间的门把手改变了$7$次,同行同列的门把手改变了$4$次(因为是$4\times 4$的矩阵),而其他位置改变了2次(对同行同列门把手做操作op时改变的)。于是就达到了我们的目的——只改变中间的门把手状态。

  3、在第2点中,对同行同列元素都做了一次操作op,即都switch了一次。看起来好像不能求得最小步数吗?但要注意在我们把原本是关着的门把手全单独打开的过程中,另外的一些门把手可能被switch了不止$1$次。最终奇数次的才是真正要去switch的。同时这个过程是可逆的,对最终需要switch的门把手都switch一遍之后,就把原本关的全都变成开的了,也就是说我们要计算和保存的是一个要不要switch的状态矩阵(当然你也又可以压缩....不推荐干这种事情,真的)。

  4、在这里,我们先把“把所有门把手都打开,需要改变哪些门把手”的大问题,分成了“单独改变某个门把手,需要改变其他哪些门把手”的小问题,并最终合并各个小问题的答案,得到最终答案,这不是分治是什么?!

  代码如下:

 #include <stdio.h>

 int sswitch[][];

 int main() {
for(int i=; i<; i++) {
for(int j=; j<; j++)
if(getchar()=='+') {
for(int k=; k<; k++) {
sswitch[i][k]^=;
sswitch[k][j]^=;
}
sswitch[i][j]^=;
}
getchar();
} int res=;
for(int i=; i<; i++)
for(int j=; j<; j++)
if(sswitch[i][j])
++res;
printf("%d\n",res); for(int i=; i<; i++)
for(int j=; j<; j++)
if(sswitch[i][j])
printf("%d %d\n",i+,j+);
return ;
}

POJ 2903 分治

——本文原创by BlackStorm,转载请注明出处。

本文链接:http://www.cnblogs.com/BlackStorm/p/5240201.html

POJ 2965. The Pilots Brothers' refrigerator 枚举or爆搜or分治的更多相关文章

  1. poj 2965 The Pilots Brothers' refrigerator枚举(bfs+位运算)

    //题目:http://poj.org/problem?id=2965//题意:电冰箱有16个把手,每个把手两种状态(开‘-’或关‘+’),只有在所有把手都打开时,门才开,输入数据是个4*4的矩阵,因 ...

  2. 枚举 POJ 2965 The Pilots Brothers' refrigerator

    题目地址:http://poj.org/problem?id=2965 /* 题意:4*4的矩形,改变任意点,把所有'+'变成'-',,每一次同行同列的都会反转,求最小步数,并打印方案 DFS:把'+ ...

  3. POJ 2965 The Pilots Brothers' refrigerator 位运算枚举

      The Pilots Brothers' refrigerator Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 151 ...

  4. poj 2965 The Pilots Brothers' refrigerator (dfs)

    The Pilots Brothers' refrigerator Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 17450 ...

  5. POJ 2965 The Pilots Brothers' refrigerator 暴力 难度:1

    The Pilots Brothers' refrigerator Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 16868 ...

  6. POJ 2965 The Pilots Brothers' refrigerator (DFS)

    The Pilots Brothers' refrigerator Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 15136 ...

  7. POJ - 2965 The Pilots Brothers' refrigerator(压位+bfs)

    The game “The Pilots Brothers: following the stripy elephant” has a quest where a player needs to op ...

  8. POJ 2965 The Pilots Brothers' refrigerator【枚举+dfs】

    题目:http://poj.org/problem?id=2965 来源:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=26732#pro ...

  9. POJ 2965 The Pilots Brothers' refrigerator (枚举+BFS+位压缩运算)

    http://poj.org/problem?id=2965 题意: 一个4*4的矩形,有'+'和'-'两种符号,每次可以转换一个坐标的符号,同时该列和该行上的其他符号也要随之改变.最少需要几次才能全 ...

随机推荐

  1. Web缓存杂谈

    一.概述 缓存通俗点,就是将已经得到的‘东东’存放在一个相对于自己而言,尽可能近的地方,以便下次需要时,不会再二笔地跑到起始点(很远的地方)去获取,而是就近解决,从而缩短时间和节约金钱(坐车要钱嘛). ...

  2. Geotrellis系列文章链接

    本文存放了我在博客园中撰写的Geotrellis系列文章链接,方便查阅! 一.geotrellis使用初探 二.geotrellis使用(二)geotrellis-chatta-demo以及geotr ...

  3. Linux 平台静默安装 Oracle客户端

    需求:Linux平台,安装完整版Oracle客户端 Tips:如果只是用到sqlldr,sqlplus功能,可以参考<Linux上oracle精简版客户端快速部署>快速部署精简版:如果需要 ...

  4. Mybatis框架 的快速入门

    MyBatis 简介 什么是 MyBatis? MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除 了几乎所有的 JDBC 代码和参数的手工设置以及结果 ...

  5. Unity iOS混合开发界面切换思路

    Unity iOS混合开发界面切换思路 最近有很多博友QQ 私信 或则 留言联系我,请教iOS和Unity界面之前相互切换的问题,源代码就不私下发你们了,界面跳转功能的代码我直接贴到下面好了,顺带说i ...

  6. 如果你也会C#,那不妨了解下F#(2):数值运算和流程控制语法

    本文链接:http://www.cnblogs.com/hjklin/p/fs-for-cs-dev-2.html 一些废话 一门语言火不火,与语言本身并没太大关系,主要看语言的推广. 推广得好,用的 ...

  7. 在DevExpress程序中使用条形码二维码控件,以及进行报表打印处理

    在很多业务系统里面,越来越多涉及到条形码.二维码的应用了,不管在Web界面还是WInform界面都需要处理很多物料相关的操作,甚至很多企业为了减少录入错误操作,为每个设备进行条形码.二维码的标签,直接 ...

  8. Eclipse "Unable to install breakpoint due to missing line number attributes..."

    Eclipse 无法找到 该 断点,原因是编译时,字节码改变了,导致eclipse无法读取对应的行了 1.ANT编译的class Eclipse不认,因为eclipse也会编译class.怎么让它们统 ...

  9. bootstrap的栅格布局与两列布局结合使用

    在工作中我们常常需要实现响应式布局,这个可以使用bootstrap的栅格系统来实现,我们在列里也需要实现一部分的响应式.比如下面的效果图,需要实现左边图标固定,右边的自适应 : 左边固定宽度,右边自适 ...

  10. Web Worker javascript多线程编程(一)

    什么是Web Worker? web worker 是运行在后台的 JavaScript,不占用浏览器自身线程,独立于其他脚本,可以提高应用的总体性能,并且提升用户体验. 一般来说Javascript ...