poj 1753 Flip Game【dfs】
2015-09-09 20:16
417 查看
[align=center]Flip Game[/align]
题目大意:给一个4x4的棋盘,棋盘上放置棋子,棋子一面白一面黑,现在给出一个棋局,让我们计算最少需要几步才能把所有棋都翻到黑面或者白面(翻棋子时,被翻棋子的上下左右的棋子也要翻);
Sample Input
Sample Output
思路:笔者先想到的是用dfs;
因为棋盘是4x4的,所以数组开个6x6的足够了;然后把数组初始化为零;每个棋子只能翻奇数次或者不翻,而翻奇数次的与翻一次的效果一样,所以对于整个过程,最多只能翻16次,从只翻0次到翻15次遍历过去;
已Accept代码(c++提交)
[align=center]Flip Game[/align]
Time Limit: 1000MS | Memory Limit: 65536K | |
Total Submissions: 34930 | Accepted: 15289 |
题目大意:给一个4x4的棋盘,棋盘上放置棋子,棋子一面白一面黑,现在给出一个棋局,让我们计算最少需要几步才能把所有棋都翻到黑面或者白面(翻棋子时,被翻棋子的上下左右的棋子也要翻);
Sample Input
bwwb bbwb bwwb bwww
Sample Output
4
思路:笔者先想到的是用dfs;
因为棋盘是4x4的,所以数组开个6x6的足够了;然后把数组初始化为零;每个棋子只能翻奇数次或者不翻,而翻奇数次的与翻一次的效果一样,所以对于整个过程,最多只能翻16次,从只翻0次到翻15次遍历过去;
已Accept代码(c++提交)
#include <iostream> using namespace std; int p[6][6] = {0}; //棋盘 bool k; int s; //累计最小需要翻的次数 int dr[] = {0, 0, 1, -1, 0}; int dc[] = {1, -1, 0, 0, 0}; bool all() { //判断是否都为 白 或 黑 for(int i = 1; i < 5; i++) for(int j = 1; j < 5; j++) if(p[i][j] != p[1][1]) return false; return true; } void fq(int r, int c){ //翻转棋子 for(int i = 0; i < 5; i++) p[r + dr[i]][c + dc[i]] =! p[r + dr[i]][c + dc[i]]; return ; } void dfs(int r, int c, int d){ if(d == s){ //判断是否 都为 白 或 黑 k = all(); return ; } if(k || r == 5) return ; fq(r, c); //翻转棋子 if(c < 4) dfs(r, c + 1, d + 1); else dfs(r + 1, 1, d + 1); fq(r, c); //恢复到上一步 if(c < 4) dfs(r, c + 1, d); else dfs(r + 1, 1, d); return ; } int main() { int i, j; char t; for(i = 1; i < 5; i++) for(j = 1; j < 5; j++){ cin >> t; if(t == 'b') p[i][j]= 1; //用 0 与 1 代表白棋和黑棋 } for(s = 0; s < 16; s++){ //从翻转 0 个到翻转 15 个遍历过去 dfs(1, 1, 0); if(k) break; } if(k) cout << s << endl; else cout << "Impossible" << endl; return 0; }还有bfs的做法和位运算的做法,明天补上:
相关文章推荐
- Word 2007 如何设置正文第一页----目录显示正文从第一页开始
- linux /sbin FHS翻译
- shell脚本操作mysql数据库 (部份参考)
- hdu 1285
- 88 thinkphp 有模型没有表
- 一个文件夹遍历工具
- Android多线程、Handler和AsyncTask的用法
- MySQL Workbench中如何开启MySQL的远程帐号
- 程序员很穷
- 字符串反转方法总结
- Android之多媒体MediaPlayer(一个简单的音乐播放器)
- 静态链表
- 项目11.1分离各位数
- UINavigationController和UIBarButtonItem
- tips
- linux 远程不能访问CentOS的tomcat 8080端口
- Alarm 闹钟列表中部分铃声相同的解决办法
- java时钟面板clock
- Erlang 函数的使用
- 动态链式表示与实现