004 四子连棋

时间限制: 1 s
空间限制: 128000 KB
题目等级 : 黄金 Gold
 
 
 
题目描述 Description

在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向上下左右四个方向移动到相邻的空格,这叫行棋一步,黑白双方交替走棋,任意一方可以先走,如果某个时刻使得任意一种颜色的棋子形成四个一线(包括斜线),这样的状态为目标棋局。

 
 
输入描述 Input Description
从文件中读入一个4*4的初始棋局,黑棋子用B表示,白棋子用W表示,空格地带用O表示。
输出描述 Output Description

用最少的步数移动到目标棋局的步数。

样例输入 Sample Input

BWBO
WBWB
BWBW
WBWO

样例输出
Sample Output

5

数据范围及提示
Data Size & Hint

hi

 
 
#include<iostream>
using namespace std;
struct data{
int mp[][];//1白棋,2黑棋,0空格
}d[];
int next[]={,};//下一步走黑棋还是白棋,1为白,2为黑
int step[];
bool hash[];
int xx[]={,,,-},yy[]={,-,,};
int t=,w=,flag=;
bool equ(int a1,int a2,int a3,int a4){if(a1!=a2||a2!=a3||a3!=a4||a4!=a1)return ;return ;}
bool check(){
for(int i=;i<=;i++)
{
if(equ(d[w].mp[i][],d[w].mp[i][],d[w].mp[i][],d[w].mp[i][]))return ;
if(equ(d[w].mp[][i],d[w].mp[][i],d[w].mp[][i],d[w].mp[][i]))return ;
}
if(equ(d[w].mp[][],d[w].mp[][],d[w].mp[][],d[w].mp[][]))return ;
if(equ(d[w].mp[][],d[w].mp[][],d[w].mp[][],d[w].mp[][]))return ;
return ;
}
int Hash(){//哈希判重
int s=,k=;
for(int i=;i<=;i++)
for(int j=;j<=;j++)
{s+=d[w].mp[i][j]*k;k*=;}
s%=;
if(!hash[s]){hash[s]=;return ;}
return ;
}
bool pd(int x,int y){
int k=next[t];
if(x>||y>||x==||y==)return ;
else if(d[t].mp[x][y]==k)return ;
return ;
}
void sp(int &a,int &b){int t=a;a=b;b=t;}
void move(int x,int y){
for(int i=;i<;i++)
{
int p=x+xx[i],q=y+yy[i];
if(pd(p,q))
{
for(int j=;j<=;j++)
for(int k=;k<=;k++)
d[w].mp[j][k]=d[t].mp[j][k];
sp(d[w].mp[x][y],d[w].mp[p][q]);
step[w]=step[t]+;
if(check()){cout<<step[w];flag=;return;}
if(Hash())
{
if(next[t]==)next[w++]=;
if(next[t]==)next[w++]=;
}
}
}
}
void search(){
while(t<w)
{
for(int i=;i<=;i++)
for(int j=;j<=;j++)
{
if(d[t].mp[i][j]==)move(i,j);
if(flag)return;
}
t++;
}
}
int main(){
char x;
for(int i=;i<=;i++)
for(int j=;j<=;j++)
{
cin>>x;
if(x=='W')d[].mp[i][j]=d[].mp[i][j]=;
else if(x=='B')d[].mp[i][j]=d[].mp[i][j]=;
}
search();
return ;
}

codevs 1004 四子连棋 BFS、hash判重的更多相关文章

  1. codevs 1004 四子连棋

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

  2. CODEVS 1004四子连棋

    [题目描述 Description] 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向上下左右四个方向移动到相邻的空格,这叫行棋一步,黑 ...

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

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

  4. Codevs p1004 四子连棋

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

  5. 【wikioi】1004 四子连棋

    题目链接 算法:BFS //2014-02-05更新 *******************************2013-10-15******************************* ...

  6. BFS搜索算法应用_Codevs 1004 四子连棋

    #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <algorithm> #include <cs ...

  7. CODEVS——T 1004 四子连棋

    http://codevs.cn/problem/1004/  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Descr ...

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

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

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

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

随机推荐

  1. Linux学习笔记-文件处理和权限命令

    目录 文件处理命令 touch cat tac more less head tail 链接命令 ln 权限命令 chmod 权限管理命令 chown chgrp umask 文件处理命令 touch ...

  2. 在jsp页面中设置了远程验证,在初始化时必须预先调用一次。

    参考链接:http://code.taobao.org/p/sztaotao/diff/5/trunk/code/src/main/webapp/webpage/modules/sys/roleFor ...

  3. python基础学习之路No.1

    版本python2 python语言不分"和',两者可以一样使用,同等效果 1.输出print python3中print是一个函数 print "hello world" ...

  4. 使用jsplumb的一些笔记

    欢迎就是需要使用jsplumb跟正在使用jsplumb的一起讨论 欢迎私聊 1.关于jsplumb的connection的一些事件 ####connection拖动的事件 instance.bind( ...

  5. VMware虚拟机的三种联网方法及原理(转)

    转自:http://blog.chinaunix.net/uid-24876683-id-3593774.html 一.Brigde——桥接 :默认使用VMnet0 .原理: Bridge 桥&quo ...

  6. apachebench对网站进行并发测试

    ,安装apache ,打开cmd进入apache安装目录的bin目录(有ab.exe) ,执行ab命令 格式:ab -n -c http://localhost:80/test/test.php 说明 ...

  7. WordPress用户登录后重定向到指定页面

    这篇文章将向您展示WordPress用户登录后如何重定向到指定页面或者文章的技巧. 一.重定向到网站管理面板. 将以下代码添加到您的当前主题的 functions.php 文件中: function  ...

  8. CI中如何保护RESTful API

    步骤5 保护RESTful API 为了保护RESTful API,可以在application/config/rest.php中设置安全保护级别,如下所示: $config['rest_auth'] ...

  9. C++拾遗——重新开始

    http://www.cnblogs.com/uniqueliu/category/307731.html

  10. day9--回顾

    线程  vs   进程 进程:一堆资源集的集合.线程:操作系统能够调度的最小单位. 进程和线程的谁快是误区,进程至少包含一个线程,是没有可比性的. 线程:共享内存,两个线程同时操作一个数据,要加锁.全 ...