博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 2965 The Pilots Brothers' refrigerator【枚举】
阅读量:6568 次
发布时间:2019-06-24

本文共 2163 字,大约阅读时间需要 7 分钟。

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 rowiand all handles in columnj.

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

分析:

在看了该题的讨论版后,得知一个高效的解法,总结如下:先看一个简单的问题,如何把'+'变成'-'而不改变其他位置上的状态?答案是将该位置(i,j)及位置所在的行(i)和列(j)上所有的handle更新一次,结果该位置被更新了7次,相应行(i)和列(j)的handle被更新了6次,剩下的被更新了4次.被更新偶数次的handle不会造成最终状态的改变.因此得出高效解法,在每次输入碰到'+'的时候,自增该位置与相应的行和列,当输入结束后,遍历数组,所有为奇数的位置则是操作的位置,而奇数位置的个数之和则是最终的操作次数.

code:

View Code
#include
#include
int main() {
char s[5]; int state[5][5]; int i,j,k,tot; memset(state,0,sizeof(state)); tot=0; for(i=0;i<4;i++) {
scanf("%s",s); for(j=0;j<4;j++) if(s[j]=='+') {
state[i+1][j+1]=!state[i+1][j+1]; for(k=1;k<=4;k++) {
state[i+1][k]=!state[i+1][k]; state[k][j+1]=!state[k][j+1]; } } } for(i=1;i<=4;i++) for(j=1;j<=4;j++) if(state[i][j]) tot++; printf("%d\n",tot); for(i=1;i<=4;i++) for(j=1;j<=4;j++) if(state[i][j]) printf("%d %d\n",i,j); return 0; }

转载于:https://www.cnblogs.com/dream-wind/archive/2012/03/16/2400019.html

你可能感兴趣的文章
window.location.replace vs window.location.href
查看>>
CVPR 2018:阿里提出应用 LocalizedGAN 进行半监督训练
查看>>
被劫持的wordpress.com账户被用来感染站点
查看>>
分享一下最近看的东西
查看>>
《大数据、小数据、无数据:网络世界的数据学术》一 第2章 何为数据 2.1 引言...
查看>>
WatchStor观察:2008年存储大事记
查看>>
寓教于乐的顶峰:新一届大学生集群竞赛火热开战
查看>>
《计算机科学与工程导论:基于IoT和机器人的可视化编程实践方法第2版》一第1章 职业发展机会和团队建设...
查看>>
HBase BlockCache系列 - 探求BlockCache实现机制
查看>>
【参与有奖】您用的MySQL、MongoDB、Redis等服务被勒索过吗?
查看>>
Java核心技术卷I基础知识1.2.6 体系结构中立
查看>>
Libvirt 虚拟化库介绍
查看>>
Xmemcached发布1.2.6.1(推荐升级)
查看>>
《Spring 5 官方文档》26. JMS(一)
查看>>
《Python Cookbook(第2版)中文版》——1.11 检查一个字符串是文本还是二进制
查看>>
Tkinter之Label
查看>>
PostgreSQL merge json的正确姿势
查看>>
java反射
查看>>
【IOS-COCOS2D游戏开发之二】COCOS2D 游戏开发资源贴(教程以及源码)
查看>>
nodejs安装记录
查看>>