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
题意:有一个4*4冰箱开关,+为关,-为开,给你一个起始状态,每次可以选择一个开关,将它连同它所在的行列一起翻转状态,求最小次数,并输出操作
题解:前一道题可以爆枚,但毕竟期望标程是bfs或dfs,所以本题我来了一份bfs
首先
因为只有4*4的大小,每个坐标(x,y)上只有两种情况,所以可以考虑把十六个位置压成一个数
然后要反转哪个位置,就只需要给该位置xor上一个数就可以了
如果要反转一堆呢?
那只需要xor这一堆位置的二进制值即可
所以先预处理好改变(1,1)-(4,4)每个点要xor上的值(推荐还是用程序预处理,手算错误较高)
然后bfs状态
至于为什么要bfs呢?
因为bfs有着优越性,因为进入队列的状态按步数从小到大排,可以保证搜到的第一个解一定是最小的
终止条件为所有的开关都被翻好了,即sta为0或65535(随自己定义的关为1或开为1而定)
至于记录路径吗emmmm和一道floyd求最小环的记录路径很像
记录转移过来的状态,然后追溯回去,依次输出。
代码:
#include<queue>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define fa puts("fuck");
using namespace std; struct node
{
int state,s;
node(int a,int b)
{
state=a;
s=b;
}
}; struct node2
{
int pa;
int i;
} path[]; int vis[],sum,map[][]; int change[]=
{
,,,,
,,,,
,,,,
,,,
}; void print(int k)
{
if(path[k].pa==sum)
{
cout<<path[k].i/+<<" "<<path[k].i%+<<endl;
return;
}
print(path[k].pa);
cout<<path[k].i/+<<" "<<path[k].i%+<<endl;
} void bfs()
{
memset(vis,,sizeof(vis));
vis[sum]=;
queue<node> q;
q.push(node(sum,));
while(!q.empty())
{
node t=q.front();
q.pop();
if(t.state==)
{
cout<<t.s<<endl;
print(t.state);
return ;
}
for(int i=; i<; i++)
{
int tsta=t.state^change[i];
int ts=t.s+;
if(!vis[tsta])
{
q.push(node(tsta,ts));
vis[tsta]=;
path[tsta].pa=t.state;
path[tsta].i=i;
}
}
}
} int main()
{
char c;
int cnt=;
for(int i=; i<=; i++)
{
for(int j=; j<=; j++)
{
cin>>c;
if(c=='-')
{
map[i][j]=;
sum+=(<<cnt);
}
else
{
map[i][j]=;
}
cnt--;
}
}
bfs();
return ;
}


POJ - 2965 The Pilots Brothers' refrigerator(压位+bfs)的更多相关文章

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

    http://poj.org/problem?id=2965 题意: 一个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 枚举or爆搜or分治

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

  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: 17450 ...

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

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

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

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

  9. POJ 2965 The Pilots Brothers' refrigerator【BFS+状压 Or 脑洞】

    题目链接: http://poj.org/problem?id=1753 题意: 给定冰箱门的开关情况,改变一个门则其所在行列的门都会发生改变,求出改变门的最少操作使得最终所有门都是打开状态. 代码: ...

随机推荐

  1. Java面试题:如何对HashMap按键值排序

    Java中HashMap是一种用于存储“键”和“值”信息对的数据结构.不同于Array.ArrayList和LinkedLists,它不会维持插入元素的顺序. 因此,在键或值的基础上排序HashMap ...

  2. 搭建JIRA汉化后乱码问题

    JIRA的简体中文乱码(使用了BIG5导致) 安装完JIRA汉化后发现一部分中文显示乱码,经检查:本来应该是UTF-8编码的却显示成Big5,Big5根本不支持简体中文的! 进入JIRA数据库后找到 ...

  3. 安装S_S相关报错的troubleshooting

    在安装S_S server时,在Debian上会出现类似如下的报错: File , in <module> sys.exit(main()) File , in main config = ...

  4. 南阳OJ 61 传纸条(一)

    传纸条(一) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5   描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行 ...

  5. 1084 Broken Keyboard

    题意:给出两个字符串(有字母,数字和下划线_组成),第一个字符串str1是由键盘输入的字符串,第二个字符串str2是屏幕显示的字符串,问键盘有哪几个按键坏了,根据输入的顺序,输出坏掉的键(仅输出一次) ...

  6. PHP通过引用传递参数

    <?php function add_some_extra(&$string) // 引入变量,使用同一个存储地址 { $string .= 'and something extra.' ...

  7. Oracle常见的表连接的方法

    1 排序合并连接SMJ Sort merge join 排序合并总结: 1 通常情况下,排序合并连接的效率远不如hash join,前者适用范围更广,hj只使用于等值连接,smj范围更广(<,& ...

  8. zabbix短信监控

    [ ] zabbix-短信报警(参考http://hanyun.blog.51cto.com/1060170/1604918 ) [ ] zabbix-电话报警(参考http://dl528888.b ...

  9. Oracle 11G的间隔(INTERVAL)分区

    -- Create table create table MS_BIGTABLE_LOG ( record_date DATE, col_1 VARCHAR2(), col_2 VARCHAR2() ...

  10. infos

    C++文件流 iostream 提供了cin cout 分别用于从标准输入读取流和向标准输出写入流cout 标准输出 屏幕 输出写入fstream文件流 cin 从标准输入读取cout 向标准输入写入 ...