【CodeVS 1004】四子连棋
http://blog.csdn.net/u013598409/article/details/43924465
相比于一年半前,代码的掌控能力强了许多。
#include <cstdio>
#include <algorithm>
#include <map>
using namespace std;
#define rep(i,a,b) for (int i=(a);i<=(b);i++)
#define per(i,a,b) for (int i=(a);i>=(b);i--)
const int dx[4]={0,0,-1,1};
const int dy[4]={-1,1,0,0};
char s[4][4];
int dep;
map<int,int> mp;
inline int cid(char c)
{
if (c=='W') return 0;
else if (c=='B') return 1;
else if (c=='O') return 2;
}
inline int ST(void)
{
int sum=0;
rep(i,0,3)
rep(j,0,3)
sum=sum*3+cid(s[i][j]);
return sum;
}
inline int Check(void)
{
char t;
rep(i,0,3)
{
t=s[i][0];
if (t==s[i][1]&&t==s[i][2]&&t==s[i][3]) return 1;
}
rep(i,0,3)
{
t=s[0][i];
if (t==s[1][i]&&t==s[2][i]&&t==s[3][i]) return 1;
}
t=s[0][0];
if (t==s[1][1]&&t==s[2][2]&&t==s[3][3]) return 1;
t=s[3][0];
if (t==s[2][1]&&t==s[1][2]&&t==s[0][3]) return 1;
return 0;
}
inline int Legal(int x,int y)
{
return 0<=x&&x<=3&&0<=y&&y<=3;
}
int DFS(int dir,int tms,int lim)
{
int st=ST();
if (mp.count(st)) return 0;
mp[st]=1;
if (tms==lim)
{
int t=Check();
return t;
}
rep(x,0,3) rep(y,0,3) if (cid(s[x][y])==dir)
rep(k,0,3)
{
int nx=x+dx[k],ny=y+dy[k];
if (Legal(nx,ny)&&cid(s[nx][ny])==2)
{
swap(s[x][y],s[nx][ny]);
int t=DFS(dir^1,tms+1,lim);
swap(s[x][y],s[nx][ny]);
if (t) return 1;
}
}
return 0;
}
int main(void)
{
// freopen("codevs1004.in","r",stdin);
// freopen("codevs1004.out","w",stdout);
rep(i,0,3)
scanf("%s",s[i]);
int t1,t2; dep=-1;
do
{
dep++;
mp.clear();
t1=DFS(0,0,dep);
mp.clear();
t2=DFS(1,0,dep);
}while (!t1&&!t2);
printf("%d\n",dep);
return 0;
}
【CodeVS 1004】四子连棋的更多相关文章
- codevs 1004 四子连棋
1004 四子连棋 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白 ...
- codevs 1004 四子连棋 BFS、hash判重
004 四子连棋 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋 ...
- CODEVS 1004四子连棋
[题目描述 Description] 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向上下左右四个方向移动到相邻的空格,这叫行棋一步,黑 ...
- Codevs p1004 四子连棋
四子连棋 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向 ...
- CODEVS——T 1004 四子连棋
http://codevs.cn/problem/1004/ 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Descr ...
- BFS搜索算法应用_Codevs 1004 四子连棋
#define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <algorithm> #include <cs ...
- 【wikioi】1004 四子连棋
题目链接 算法:BFS //2014-02-05更新 *******************************2013-10-15******************************* ...
- 迭代加深搜索[codevs1004 四子连棋]
迭代加深搜索 一.算法简介 迭代加深搜索是在速度上接近广度优先搜索,空间上和深度优先搜索相当的搜索方式.由于在使用过程中引入了深度优先搜索,所以也可以当作深度优先搜索的优化方案. 迭代加深搜索适用于当 ...
- 【宽度优先搜索】神奇的状态压缩 CodeVs1004四子连棋
一.写在前面 其实这是一道大水题,而且还出在了数据最水的OJ上,所以实际上这题并没有什么难度.博主写这篇blog主要是想写下一个想法--状态压缩.状态压缩在记录.修改状态以及判重去重等方面有着极高的( ...
- codevs1004四子连棋[BFS 哈希]
1004 四子连棋 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗 ...
随机推荐
- CSS3那些不为人知的高级属性
尽管现代浏览器已经支持了众多的CSS3属性,但是大部分设计师和开发人员貌似依然在关注于一些很“主流”的属性,如border-radius.box-shadow或者transform等.它们有良好的文档 ...
- IOSView显示特性设置
一.主要用途 弹出模态ViewController是IOS变成中很有用的一个技术,UIKit提供的一些专门用于模态显示的ViewController,如UIImagePickerController等 ...
- null&this&super&向上转型
向上转型:父类声明子类实例化对象 例如A是父类 B是子类 1 : 实际上是父类的对象但将会丢失子类没有的父类方法 ,如果调用方法 将会调用子类重写的父类方法 2:上转型对象不能调用子类新增 ...
- FragMent 初级学习
FragMent 可以用在一个Activity中也可以用在多个Activity中 我们在activity中加载FragMent的时候,首先添加一个myFragMent的类 通过onCreateView ...
- STREAM Benchmark
STREAM Benchmark及其操作性能分析 文/raywill STREAM 是业界广为流行的综合性内存带宽实际性能 测量 工具之一.随着处理器处理核心数量的增多,内存带宽对于提升整个系统性能越 ...
- [51NOD1095] Anigram单词(map)
题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1095 字典的单词在map中排序和不排序各存1次,查的时候相减. ...
- QUEEN_BLADE_2D-非常屌-113P
http://www.cgvoo.com/thread-33670-1-2.html http://blog.sina.com.cn/s/blog_4b92d6070102e7gj.html http ...
- phpcms 头部搜索栏上边的 “新闻 | 图片 | 下载 | 专题” 是在哪里修改的?
phpcms 是怎么修改以下 栏目列. 在后台的时候,“模块管理>全站搜索”,可以修改搜索分类
- 关于<![CDATA[]]
术语 CDATA 指的是不应由 XML 解析器进行解析的文本数据(Unparsed Character Data). 在 XML 元素中,"<" 和 "&& ...
- V8 引擎的sort算法
用的是快速排序,有点小问题 function ArraySort(comparefn) { // In-place QuickSort algorithm. // For short (length ...