P2346 四子连棋
P2346 四子连棋
迭代加深++
题意描述
在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向上下左右四个方向移动到相邻的空格,这叫行棋一步,黑白双方交替走棋,任意一方可以先走,如果某个时刻使得任意一种颜色的棋子形成四个一线(包括斜线),这样的状态为目标棋局。求达到目标棋局的最小步数。
看不懂的话,右手传送门
算法分析
求最小步数,数据范围又那么小,肯定可以用搜索,
那么在bfs/dfs中选一个吧,bfs肯定没问题(OIer都知道),
但dfs的话,你就不知道搜索深度了,所以不能用?
不是的,有一个具有bfs+dfs双重特性的算法:ID****(迭代加深)
- 什么是迭代加深?百度去吧。
- bfs和ID哪个快?ID(仅限本题)
知道用什么算法就好办了,但还要注意几个细节:
- 题目是黑白棋子交替行走,所以搜索时既可以黑子开局也可以白子开局。
- 题目是有2个白格子,要分别搜索。
然后就可以AC了
代码实现
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<iostream>
#include<cmath>
using namespace std;
int a[10][10],d=1;
int dx[5]={0,1,-1,0,0};
int dy[5]={0,0,0,1,-1};
bool check(){
for(int i=1;i<=4;i++){
if(a[i][1]==a[i][2]&&a[i][2]==a[i][3]&&a[i][3]==a[i][4]) return true;
if(a[1][i]==a[2][i]&&a[2][i]==a[3][i]&&a[3][i]==a[4][i]) return true;
}
if(a[1][1]==a[2][2]&&a[2][2]==a[3][3]&&a[3][3]==a[4][4]) return true;
if(a[1][4]==a[2][3]&&a[2][3]==a[3][2]&&a[3][2]==a[4][1]) return true;
return false;
}
bool dfs(int fx,int fy,int fxx,int fyy,int color,int step){
if(step==d){
if(check()) return true;
return false;
}
for(int i=1;i<=4;i++){
int gx=fx+dx[i];
int gy=fy+dy[i];
int gxx=fxx+dx[i];
int gyy=fyy+dy[i];
if(gx>=1&&gx<=4&&gy>=1&&gy<=4&&a[gx][gy]!=color){
swap(a[fx][fy],a[gx][gy]);
if(dfs(gx,gy,fxx,fyy,color==1?2:1,step+1)) return true;
swap(a[fx][fy],a[gx][gy]);
}
if(gxx>=1&&gxx<=4&&gyy>=1&&gyy<=4&&a[gxx][gyy]!=color){
swap(a[fxx][fyy],a[gxx][gyy]);
if(dfs(fx,fy,gxx,gyy,color==1?2:1,step+1)) return true;
swap(a[fxx][fyy],a[gxx][gyy]);
}
}
return false;
}
int main(){
int fx1=0,fy1,fx2,fy2;
char ch;
for(int i=1;i<=4;i++){
for(int j=1;j<=4;j++){
cin>>ch;
if(ch=='B') a[i][j]=1;
else if(ch=='W') a[i][j]=2;
else{
if(!fx1){fx1=i;fy1=j;}
else{fx2=i;fy2=j;}
}
}
}
/*for(int i=1;i<=4;i++){
for(int j=1;j<=4;j++){
printf("%d",a[i][j]);
}
printf("\n");
}
printf("%d %d %d %d\n",fx1,fy1,fx2,fy2);*/
while(1){
if(dfs(fx1,fy1,fx2,fy2,1,0)){printf("%d\n",d);break;}
if(dfs(fx1,fy1,fx2,fy2,2,0)){printf("%d\n",d);break;}
d++;
}
return 0;
}
结语
ID
P2346 四子连棋的更多相关文章
- 洛谷P2346四子连棋
题目描述 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向上下左右四个方向移动到相邻的空格,这叫行棋一步. 黑白双方交替走棋,任意一方可 ...
- 【洛谷 P2346】四子连棋(状态压缩,搜索)
其实这题可以直接二进制状压做,1表示黑棋,0表示白棋,另外记录下2个空点的位置就行了. 具体看代码(冗长): #include <iostream> #include <cstdio ...
- 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 四子连棋
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颗白色棋 ...
- 迭代加深搜索[codevs1004 四子连棋]
迭代加深搜索 一.算法简介 迭代加深搜索是在速度上接近广度优先搜索,空间上和深度优先搜索相当的搜索方式.由于在使用过程中引入了深度优先搜索,所以也可以当作深度优先搜索的优化方案. 迭代加深搜索适用于当 ...
- codevs1004四子连棋
1004 四子连棋 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白 ...
随机推荐
- mysql-15-view
#视图 /* 含义:虚拟表,和普通表一样使用.通过表动态生成的数据 只保存了sql逻辑,不保存查询结果 应用场景: 1.多个地方用到同样的查询结果 2.该查询结果使用的sql语句较为复杂 */ USE ...
- Jetson AGX Xavier/ubuntu查找文件
用以下命令查找文件 sudo updatedb locate xxx #xxx是文件名 如果找不到命令,则需要安装mlocate sudo apt-get install mlocate
- shell-变量的数值运算-bc-typeset-中括号等方法介绍
1. bc命令的用法: bc是unix下的计算器,它也可以用在命令行下面: 例:给自变量i加1 i=2 i=`echo $i + 1|bc` --------效率低 因为bc支持科学计算 ...
- HanLP的分词统计
HanLP的分词效果鄙人研究了HanLP,他的分词效果确实还可以,而且速度也比较快,10的数据是9000毫秒 @SneakyThrows@Overridepublic LinkedHashMap< ...
- JAVA对象头详解(含32位虚拟机与64位虚拟机)
为什么要学习Java对象头 学习Java对象头主要是为了解synchronized底层原理,synchronized锁升级过程,Java并发编程等. JAVA对象头 由于Java面向对象的思想,在JV ...
- C语言和单片机C语言为什么会有差异?虽不同但理同!
许多小伙伴在学完C语言后想入门单片机,但学着学着发现明明都是C语言,为什么单片机C语言和我当初学的C语言有差异呢? 今天小编就来梳理我们平时所学的C语言与单片机C语言的有什么样的不同. 单片机c语言比 ...
- 为了运行十年前的代码,程序员们甚至翻出了一台 1977 年的 Apple II
"Hello, World!" 46 年过去,这段被世人熟知的代码仍散发着历久弥新的魅力,和它一起登场的 C 语言,如今也成长为世界几大通行编程语言之一,为互联网世界乃至现实世界都 ...
- Shell Scripting 笔记
Shell Scripting Tutorial Variables in the Bourne shell do not have to be declared, as they do in lan ...
- 解决/lib/ld-linux.so.2: bad ELF interpreter: No such file or directory报错 (转)
解决/lib/ld-linux.so.2: bad ELF interpreter: No such file or directory报错 念淅 2020-01-03 15:02:25 3793 收 ...
- go 正则 爬取邮箱代码
package main import ( "net/http" "fmt" "io/ioutil" "regexp" ...