codevs1044四子连棋(Dfs)
/*
数据范围太小 暴力暴力 Dfs直接
终止条件嘛 就是4中目标棋局 挨着枚举一遍就好了
搜索的起点一定是空格 当然 空格周围有黑有白 黑先走或者白先走答案可能不一样
所以 维护一个b 表示这一步走那种颜色 b=1先走白棋 b=2先走黑棋 */
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
int xx[]={,,,,-};//枚举四个方向
int yy[]={,,-,,};
int g[][],minn=;//最小步数
char s;
void Dfs(int x,int y,int num,int b)//b表示 先走那种颜色
{
int m=,i,j,k;
if(num>=minn) return; //剪枝 如果已经比目前的最优解大了 就不用再Dfs了
for(i=;i<=;i++)//4种目标棋局一一列举 如果有符合的 更新m的值
{
if(g[i][]==g[i][]&&g[i][]==g[i][]&&g[i][]==g[i][]&&(g[i][]==||g[i][]==))m=num;
if(g[][i]==g[][i]&&g[][i]==g[][i]&&g[][i]==g[][i]&&(g[][i]==||g[][i]==))m=num;
}
if(g[][]==g[][]&&g[][]==g[][]&&g[][]==g[][]&&(g[][]==||g[][]==))m=num;
if(g[][]==g[][]&&g[][]==g[][]&&g[][]==g[][]&&(g[][]==||g[][]==))m=num;
if(m<minn)//用m更新minn
{
minn=m;
return;//不用往后Dfs了 因为后面不如现在优
}
for(i=;i<=;i++)
{
int ox=x+xx[i];
int oy=y+yy[i];
if(ox>&&ox<=&&oy>&&oy<=&&g[ox][oy]==b)
{
g[x][y]=g[ox][oy];
g[ox][oy]=;//走完之后g[ox][oy]变空 g[x][y]变g[ox][oy]
if(b==)b=;//黑白交替走 上次走黑 下次走白
else b=;
for(j=;j<=;j++)//因为空格又不止一个 所以 找空格0.0
for(k=;k<=;k++)
if(!g[j][k])//空
Dfs(j,k,num+,b);
g[ox][oy]=g[x][y];//回溯
g[x][y]=;
if(b==)b=;
else b=;
}
}
}
int main()
{
int i,j;
for(i=;i<=;i++)
for(j=;j<=;j++)
{
cin>>s;
if(s=='W')g[i][j]=;//白棋
if(s=='B')g[i][j]=;//黑棋
}
for(i=;i<=;i++)
for(j=;j<=;j++)
if(!g[i][j])//空格
{
Dfs(i,j,,);//先走白棋
Dfs(i,j,,);//先走黑棋
}
cout<<minn<<endl;
return ;
}
codevs1044四子连棋(Dfs)的更多相关文章
- codevs 1004 四子连棋
1004 四子连棋 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白 ...
- 迭代加深搜索[codevs1004 四子连棋]
迭代加深搜索 一.算法简介 迭代加深搜索是在速度上接近广度优先搜索,空间上和深度优先搜索相当的搜索方式.由于在使用过程中引入了深度优先搜索,所以也可以当作深度优先搜索的优化方案. 迭代加深搜索适用于当 ...
- codevs1004四子连棋
1004 四子连棋 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白 ...
- P2346 四子连棋
P2346 四子连棋 迭代加深++ 题意描述 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向上下左右四个方向移动到相邻的空格,这叫行棋 ...
- codevs1004四子连棋[BFS 哈希]
1004 四子连棋 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗 ...
- Codevs p1004 四子连棋
四子连棋 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向 ...
- 【宽度优先搜索】神奇的状态压缩 CodeVs1004四子连棋
一.写在前面 其实这是一道大水题,而且还出在了数据最水的OJ上,所以实际上这题并没有什么难度.博主写这篇blog主要是想写下一个想法--状态压缩.状态压缩在记录.修改状态以及判重去重等方面有着极高的( ...
- codevs 1004 四子连棋 BFS、hash判重
004 四子连棋 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋 ...
- 【洛谷 P2346】四子连棋(状态压缩,搜索)
其实这题可以直接二进制状压做,1表示黑棋,0表示白棋,另外记录下2个空点的位置就行了. 具体看代码(冗长): #include <iostream> #include <cstdio ...
随机推荐
- centos升级python到2.7
最近在阿里云租了一个云主机,打算部署自己的个人网站,但是centos系统的默认Python是2.6版本,打算升级到2.7.3! 查看python的版本 #python -V Python 2.6.6 ...
- Java中权限修饰符public、private、protected和default的区别
1.public 可以修饰类.成员变量和成员函数,没有任何限制,同一个包中,或者不同包中的类都可以自由访问 2.private 可以修饰成员变量和成员函数,只能在本类中使用 3.default (不写 ...
- Thinking In Java 学习笔记 1-5 章
第1章 对象导论 本章主要讲OOP的思想及一些OOP基本概念 1.抽象过程:万物都是对象,对象具有状态.行为和标识.对象拥有属性和方法,以及在内存中的唯一地址. 2.每个对象都有一个接口:通过接口给对 ...
- 【video】m3u8
Safari浏览器识别不了.UC浏览器可以识别. 优酷的Safari浏览器和UC浏览器都可以识别.
- 【转】Android开发中adb启动失败adb连接异常的解决办法 offline
原文网址:http://www.cnblogs.com/yejiurui/p/4173521.html 一.情况描述: 我们在使用eclipse开发有时候会出现adb连接异常中,有时候控制台会打印出来 ...
- OC中的野指针(僵尸指针)
涉及到内存管理问题的都是类类型的变量,而在OC中我们操纵这些对象都是通过操纵指向他们的指针来完成的,一致很多时候会忽略指针存在.比如定义UIView * view = [[UIView alloc]i ...
- 树(最小乘积生成树,克鲁斯卡尔算法):BOI timeismoney
The NetLine company wants to offer broadband internet to N towns. For this, it suffices to construct ...
- 【模拟】Codeforces 699A Launch of Collider
题目链接: http://codeforces.com/problemset/problem/699/A 题目大意: 给N个点,向左或向右运动,速度均为1,问最早什么时候有两个点相撞.无解输出-1 题 ...
- Vim笔记
复制多行: v 可视化,选择多行,然后yy复制.
- vector::erase returns incompatible iterator in debug build
关于std::vector中erase的用法http://www.cplusplus.com/reference/vector/vector/erase/ #include <vector> ...