这两道题类似,前者翻转上下左右相邻的棋子,使得棋子同为黑或者同为白。后者翻转同行同列的所有开关,使得开关全被打开。

poj 1753

题意:有一4x4棋盘,上面有16枚双面棋子(一面为黑,一面为白), 当翻动一只棋子时,该棋子上下左右相邻的棋子也会同时翻面。以b代表黑面,w代表白面,给出一个棋盘状态,     问从该棋盘状态开始,使棋盘变成全黑或全白,至少需要翻转多少步

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std; int mp[5][5];
int step,flag;
int range()//遍历整个棋盘是否“清一色”
{
for(int i=0;i<4;i++)
for(int j=0;j<4;j++)
if(mp[i][j]!=mp[0][0])
return 0;
return 1;
}
void turn(int i,int j)//翻转(i,j)棋子,以及(i,j)周围的棋子
{
mp[i][j]=!mp[i][j];
if(i>0) mp[i-1][j]=!mp[i-1][j];
if(i<3) mp[i+1][j]=!mp[i+1][j];
if(j>0) mp[i][j-1]=!mp[i][j-1];
if(j<3) mp[i][j+1]=!mp[i][j+1];
}
int dfs(int i,int j,int k)
{
if(k==step){
flag = range();
return 0;
}
if(flag||i==4){
return 1;
}
turn(i,j);
if(j<3) dfs(i,j+1,k+1);//一行当中的所有列
else dfs(i+1,0,k+1);//下一行
turn(i,j);//回溯,翻回来
if(j<3) dfs(i,j+1,k);//下一个棋子继续dfs
else dfs(i+1,0,k);
return 0;
}
int main()
{
char str[5][5];
for(int i=0;i<4;i++)
cin>>str[i];
for(int i=0;i<4;i++)
for(int j=0;j<4;j++)
if(str[i][j]=='b') mp[i][j]=1;
else mp[i][j]=0;
for(step=0;step<=16;step++)
{
flag = 0;
dfs(0,0,0);//(x,y),step
if(flag) break;
}
if(flag) printf("%d\n",step);
else printf("Impossible\n");
return 0;
}

poj 2965

一个冰箱上有4*4共16个开关,改变任意一个开关的状态(即开变成关,关变成开)时,此开关的同一行、同一列所有的开关都会自动改变状态。要想打开冰箱,要所有开关全部打开才行。

输入:一个4×4的矩阵,+表示关闭,-表示打开;

输出:使冰箱打开所需要执行的最少操作次数,以及所操作的开关坐标。

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int Max = 0x3f3f3f3f;
int mp[5][5];
char str[5][5];
int tx[20],ty[20],ansX[20],ansY[20],ans;
int range()//判断是否“清一色”
{
for(int i=0;i<4;i++)
for(int j=0;j<4;j++)
if(mp[i][j]==1)
return 0;
return 1;
}
void turn(int x,int y)//翻转同(i,j)同行同列的开关
{
for(int i=0;i<4;i++)
{
mp[x][i]=!mp[x][i];
mp[i][y]=!mp[i][y];
}
mp[x][y]=!mp[x][y];
}
void dfs(int x,int y,int step)
{
int check = range();
if(check==1){ //开关全打开(为0)
if(step<ans){
ans = step;
for(int i=0;i<step;i++){
ansX[i]=tx[i];
ansY[i]=ty[i];
}
}
return;
}
if(x>3||step>16) return;
turn(x,y);
tx[step]=x; ty[step]=y; if(y<3) dfs(x,y+1,step+1);
else dfs(x+1,0,step+1);
turn(x,y);//回溯,翻回来
if(y<3) dfs(x,y+1,step);
else dfs(x+1,0,step);
return ;
}
int main()
{
for(int i=0;i<4;i++)
cin>>str[i];
for(int i=0;i<4;i++)
for(int j=0;j<4;j++)
if(str[i][j]=='+') mp[i][j]=1;
else mp[i][j]=0;
ans = Max;
dfs(0,0,0);//(x,y),step cout<<ans<<endl;
for(int i=0;i<ans;i++)
printf("%d %d\n",ansX[i]+1,ansY[i]+1);
return 0;
}

递归的题总是要把人绕进去,特别是回溯那个地方。第二题还可以用其他的解法,解法很多,代码简单,但是数学不过关,看不懂,下次再看看。

poj 1753 2965的更多相关文章

  1. [ACM训练] 算法初级 之 基本算法 之 枚举(POJ 1753+2965)

    先列出题目: 1.POJ 1753 POJ 1753  Flip Game:http://poj.org/problem?id=1753 Sample Input bwwb bbwb bwwb bww ...

  2. 枚举 POJ 1753 Flip Game

    题目地址:http://poj.org/problem?id=1753 /* 这题几乎和POJ 2965一样,DFS函数都不用修改 只要修改一下change规则... 注意:是否初始已经ok了要先判断 ...

  3. POJ 1753. Flip Game 枚举or爆搜+位压缩,或者高斯消元法

    Flip Game Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 37427   Accepted: 16288 Descr ...

  4. POJ 1222 POJ 1830 POJ 1681 POJ 1753 POJ 3185 高斯消元求解一类开关问题

    http://poj.org/problem?id=1222 http://poj.org/problem?id=1830 http://poj.org/problem?id=1681 http:// ...

  5. POJ 1753 Flip Game(高斯消元+状压枚举)

    Flip Game Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 45691   Accepted: 19590 Descr ...

  6. 穷举(四):POJ上的两道穷举例题POJ 1411和POJ 1753

    下面给出两道POJ上的问题,看如何用穷举法解决. [例9]Calling Extraterrestrial Intelligence Again(POJ 1411) Description A mes ...

  7. poj 1753、2965枚举

    1753题目链接 题目大意: 一个4乘4的棋盘,上面放满了正反两面分别为黑和白的棋子,翻转一个棋子会让这个棋子上下左右的棋子也翻转,给定一个初始状态,求使所有棋子颜色相同所需的最少翻转次数. 解题思路 ...

  8. POJ 1753 (开关问题+高斯消元法)

    题目链接: http://poj.org/problem?id=1753 题目大意:一堆格子,或白或白.每次可以把一个改变一个格子颜色,其上下左右四个格子颜色也改变.问最后使格子全部白或全部黑,求最小 ...

  9. poj 1753 Flip Game 枚举(bfs+状态压缩)

    题目:http://poj.org/problem?id=1753 因为粗心错了好多次……,尤其是把1<<15当成了65535: 参考博客:http://www.cnblogs.com/k ...

随机推荐

  1. taglib简介

    在 JSP最佳实践的 上一期,您学习了一种基于scriptlet的技术,这种技术被用来将上次修改的时间戳添加到JavaServer Page(JSP)文件中.不幸的是,比起它所提供的短期利益,scri ...

  2. ftp上传文件异常

    ftp一个服务器 如果是22端口 ssh-2.0-openssh_4.3 ,是什么意思? ftp服务用的是20.21端口,客户端添加ftp信息的时候输入的是21端口 ssh服务用的是22端口,应用于远 ...

  3. iOS.CodeSign

    Inside Code Signing 1. Code Signing需要的基础组件: 证书,私钥 As an iOS developer, chances are you have a certif ...

  4. 显示实现接口的好处c#比java好的地方

    所谓Go语言式的接口,就是不用显示声明类型T实现了接口I,只要类型T的公开方法完全满足接口I的要求,就可以把类型T的对象用在需要接口I的地方.这种做法的学名叫做Structural Typing,有人 ...

  5. 10个办法让设计小白迅速get海报设计要点!

    对于设计师而言,海报和宣传单的设计,几乎是每一个设计师的必修课.如今网页上的 Banner.宣传和促销的数字海报,大多脱胎于我们所熟知的海报设计. 对于推销产品.连接客户,海报始终是一种最为有趣和实用 ...

  6. merge_关系

    create(olive:Person{chau:"Bill White",name:"Olive Stone",bornin:"New York&q ...

  7. boost asio 一个聊天的基本框架

    示例代码 #include "Util.h" #include "MyAsio.h" #include "TcpConnectionManager.h ...

  8. robot framework 中should be true 与should contain 的区别

    should be true  是否等于:判断是否should contain  是否包含 a是否包含b

  9. Selenium+python入门

    在 WebDriver 中, 将这些关于鼠标操作的方法封装在 ActionChains 类提供 ActionChains 类提供了鼠标操作的常用方法: perform(): 执行所有 ActionCh ...

  10. 装箱问题(NOIP2001&水题测试2017082401)

    题目链接:装箱问题 这题经典的01背包. 动规. 设计状态f[n][V]表示前n个物体放在V中的最大体积是多少. 所以代码如下: #include<bits/stdc++.h> using ...