https://www.luogu.org/problemnew/show/P2346

广搜

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue> #define maxn 10010
#define inf 1000000007
#define ll long long using namespace std;
int n, m, ans = inf; int dx[] = {, , , -, };
int dy[] = {, , , , -}; struct Node {
int a[][];
int color;
int step;
} t; queue <Node> q; bool check(Node f) {
for(int i = ; i <= ; i ++) {
if(f.a[i][] == f.a[i][] && f.a[i][] == f.a[i][] && f.a[i][] == f.a[i][]) return ;
if(f.a[][i] == f.a[][i] && f.a[][i] == f.a[][i] && f.a[][i] == f.a[][i]) return ;
}
if(f.a[][] == f.a[][] && f.a[][] == f.a[][] && f.a[][] == f.a[][]) return ;
if(f.a[][] == f.a[][] && f.a[][] == f.a[][] && f.a[][] == f.a[][]) return ;
return ;
} void init() { //处理一开始的棋子颜色
t.step = ;
t.color = ;
for(int i = ; i <= ; i ++)
for(int j = ; j <= ; j ++)
if(t.a[i][j] == )
for(int k = ; k <= ; k ++) {
int x = i + dx[k];
int y = j + dy[k];
if(t.a[x][y] == ) continue ;
if(x >= && x <= && y >= && y <= ) { //注意边界
Node c = t;
c.color = t.a[x][y];
c.step = ;
swap(c.a[i][j], c.a[x][y]);//移动棋子
q.push(c);
}
}
} void bfs() { //广搜模板
while(!q.empty()) {
Node b = q.front();
q.pop();
if(check(b)) {
ans = b.step;
return ;
}
for(int i = ; i <= ; i ++)
for(int j = ; j <= ; j ++) {
if(b.a[i][j] == ) {
for(int k = ; k <= ; k ++) {
int x = i + dx[k];
int y = j + dy[k];
if(x >= && x <= && y >= && y <= && b.a[x][y] == (b.color ^ )) { //黑白交替移动
Node c = b;
swap(c.a[i][j], c.a[x][y]);//移动棋子
c.color = b.color ^ ;//如果上一步走的是黑,这一步就是白,上一步是白,这一步是黑。
c.step = b.step + ;//步数加一
q.push(c);//将当前状态入队
}
}
}
}
}
} int main() {
int x, y, z;
char s[];
for(int i = ; i <= ; i ++) {
scanf("%s",s+);
for(int j = ; j <= ; j ++) { //处理图,便于广搜
if(s[j] == 'B') t.a[i][j] = ;
if(s[j] == 'W') t.a[i][j] = ;
if(s[j] == 'O') t.a[i][j] = ;
}
}
init();
bfs();
printf("%d\n", ans);
return ;
}

[Luogu] 四子连棋的更多相关文章

  1. codevs1004四子连棋[BFS 哈希]

    1004 四子连棋   时间限制: 1 s   空间限制: 128000 KB   题目等级 : 黄金 Gold   题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗 ...

  2. Codevs p1004 四子连棋

                          四子连棋 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向 ...

  3. 【宽度优先搜索】神奇的状态压缩 CodeVs1004四子连棋

    一.写在前面 其实这是一道大水题,而且还出在了数据最水的OJ上,所以实际上这题并没有什么难度.博主写这篇blog主要是想写下一个想法--状态压缩.状态压缩在记录.修改状态以及判重去重等方面有着极高的( ...

  4. codevs 1004 四子连棋

    1004 四子连棋  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold     题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白 ...

  5. codevs 1004 四子连棋 BFS、hash判重

    004 四子连棋 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold       题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋 ...

  6. 【洛谷 P2346】四子连棋(状态压缩,搜索)

    其实这题可以直接二进制状压做,1表示黑棋,0表示白棋,另外记录下2个空点的位置就行了. 具体看代码(冗长): #include <iostream> #include <cstdio ...

  7. 迭代加深搜索[codevs1004 四子连棋]

    迭代加深搜索 一.算法简介 迭代加深搜索是在速度上接近广度优先搜索,空间上和深度优先搜索相当的搜索方式.由于在使用过程中引入了深度优先搜索,所以也可以当作深度优先搜索的优化方案. 迭代加深搜索适用于当 ...

  8. codevs1004四子连棋

    1004 四子连棋  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold     题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白 ...

  9. P2346 四子连棋

    P2346 四子连棋 迭代加深++ 题意描述 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向上下左右四个方向移动到相邻的空格,这叫行棋 ...

随机推荐

  1. SAS学习笔记5 字符截取语句(index、compress、substr、scan函数)

    index:返回一个字符串中,某个特定字符或字符串的位置,找不到时返回0 compress:从一个字符串移除特定的字符 substr函数 字符替换与提取字符 substr(s, p, n)从变量s的第 ...

  2. SVM的概率输出(Platt scaling)

    SVM的概率输出(Platt scaling) 2015-10-22 10:38:19 闲渔Love吉他 阅读数 8121 文章标签: Platt Scaling Calibr 更多 分类专栏: 计算 ...

  3. (一)SpringBoot之简介和安装插件以及HelloWorld第一个程序

    一.简介 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的 ...

  4. centos从安装到环境配置

    1.安装centos6.5    http://jingyan.baidu.com/article/25648fc1a235c99191fd0008.html 2.配置网络ip   http://ji ...

  5. 校验用户名是否存在(ajax+jackson)

    只是简单的仿某度注册的用户名输入离焦后检验 目录结构 没有涉及到数据库 html <!DOCTYPE html> <html lang="en"> < ...

  6. 如何将Chrome本地安装的扩展应用导出到本地

    有时由于种种原因,我们不能直接使用Chrome web store进行Chrome扩展应用的安装,这时可以让一位已经安装了某Chrome扩展应用的朋友将他的应用导出到本地成为.crx文件,然后发给你, ...

  7. 【vue开发】vue插件的install方法

    MyPlugin.install = function (Vue, options) { // 1. 添加全局方法或属性 Vue.myGlobalMethod = function () { // 逻 ...

  8. dubbo常见异常及解决方式

    1.出现RpcException: Failed to invoke the method post in the service com.xxx.xxx.xxx异常怎么办?表示调用失败1.检查网络是 ...

  9. swoole httpserver学习

    文件 HttpServer.php <?php /** * Created by PhpStorm. * User: mac * Date: 2019/9/13 * Time: 21:00 */ ...

  10. 《数据结构与算法之美》 <06>栈:如何实现浏览器的前进和后退功能?

    浏览器的前进.后退功能,我想你肯定很熟悉吧? 当你依次访问完一串页面 a-b-c 之后,点击浏览器的后退按钮,就可以查看之前浏览过的页面 b 和 a.当你后退到页面 a,点击前进按钮,就可以重新查看页 ...