题目描述

你玩过华容道的游戏吗?这是个类似的,但更简单的游戏。看下面 3 x 2 的格子

    +---+---+---+
| A | * | * |
+---+---+---+
| B | | * |
+---+---+---+

在其中放5张牌,其中A代表关羽,B代表张飞,* 代表士兵。还有一个格子是空着的。
你可以把一张牌移动到相邻的空格中去(对角不算相邻)。
游戏的目标是:关羽和张飞交换位置,其它的牌随便在哪里都可以。 

输入

输入存在多组测试数据,对于每组测试数据: 
输入两行6个字符表示当前的局面 

输出

对于每组测试数据输出一个整数表示答案 

样例输入 Copy

* A
**B
A B
***

样例输出 Copy

17
12
分析:
  1.此题时时刻刻抓住A、B、空格这三个点的位置,知道这三个点的位置等于知道整张图,通过sig数组来记录三点的行和列位置,从而记录整张图
  2.BFS的起点是空格,后面遍历也是空格,遍历到哪儿,空格就在哪儿
  3.向空格上下左右遍历,如遇到A点或B点,需交换空格与A点、B点的位置,也就是更新空格,A点,B点三点的位置。
  4.遍历需要记录图的时时情况的,如果情况重复则不进行下去,如果此图的情况未出现过才进行
  5.直到A、B两点位置交换的图的情况出现终止,并输出步数
 #include <iostream>
#include <algorithm>
#include <string>
#include <string.h>
#include <vector>
#include <queue>
#include <cstdio>
#include <iomanip>
using namespace std; const int ROW = ;
const int COL = ;
char matrix[ROW][COL];
int arow,brow,acol,bcol,row,col;
int dd[][] = {,,,-,,,-,};
int sig[ROW][COL][ROW][COL][ROW][COL]; struct Node {
int i,j;
int ai,aj;
int bi,bj;
int step;
}; void bfs() {
queue<Node> q;
Node now;
now.i = row;
now.j = col;
now.ai = arow;now.aj = acol;
now.bi = brow;now.bj = bcol;
now.step = ;
q.push(now);
while (!q.empty()) {
now = q.front();
q.pop();
if(sig[now.ai][now.aj][now.bi][now.bj][now.i][now.j] == )
continue;
sig[now.ai][now.aj][now.bi][now.bj][now.i][now.j] = ;
if(now.ai == brow && now.aj == bcol && now.bi == arow && now.bj == acol ) {
cout<< now.step <<endl;
return ;
}
for (int i = ;i < ;i++) {
int ii = now.i + dd[i][];
int jj = now.j + dd[i][];
if (ii < || ii >= ROW || jj < || jj >= COL)
continue;
Node zz = now;
zz.i = ii;zz.j = jj;
zz.step++;
if (ii == now.ai && jj == now.aj) {
zz.aj = now.j;
zz.ai = now.i;
}
if (ii == now.bi && jj == now.bj) {
zz.bj = now.j;
zz.bi = now.i;
}
if (sig[zz.ai][zz.aj][zz.bi][zz.bj][zz.i][zz.j])
continue;
q.push(zz);
}
}
} int main() {
while (gets(matrix[]) != NULL ) {
gets(matrix[]);
memset(sig,, sizeof(sig));
for (int i = ; i < ROW; i++) {
for (int j = ; j < COL; j++) {
if (matrix[i][j] == ' ') {
row = i;
col = j;
}
if (matrix[i][j] == 'A') {
arow = i;
acol = j;
}
if (matrix[i][j] == 'B') {
brow = i;
bcol = j;
}
}
}
bfs();
}
return ;
}
 

BFS(广度优先搜索华容道游戏)--11--BFS--蓝桥杯卡片换位的更多相关文章

  1. 蓝桥杯 卡片换位(bfs)

    卡片换位 你玩过华容道的游戏吗?这是个类似的,但更简单的游戏.看下面 3 x 2 的格子 在其中放5张牌,其中A代表关羽,B代表张飞,* 代表士兵.还有一个格子是空着的. 你可以把一张牌移动到相邻的空 ...

  2. 算法竞赛——BFS广度优先搜索

    BFS 广度优先搜索:一层一层的搜索(类似于树的层次遍历) BFS基本框架 基本步骤: 初始状态(起点)加到队列里 while(队列不为空) 队头弹出 扩展队头元素(邻接节点入队) 最后队为空,结束 ...

  3. 0算法基础学算法 搜索篇第二讲 BFS广度优先搜索的思想

    dfs前置知识: 递归链接:0基础算法基础学算法 第六弹 递归 - 球君 - 博客园 (cnblogs.com) dfs深度优先搜索:0基础学算法 搜索篇第一讲 深度优先搜索 - 球君 - 博客园 ( ...

  4. BFS广度优先搜索 poj1915

    Knight Moves Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 25909 Accepted: 12244 Descri ...

  5. 图的遍历BFS广度优先搜索

    图的遍历BFS广度优先搜索 1. 简介 BFS(Breadth First Search,广度优先搜索,又名宽度优先搜索),与深度优先算法在一个结点"死磕到底"的思维不同,广度优先 ...

  6. GraphMatrix::BFS广度优先搜索

    查找某一结点的邻居: virtual int firstNbr(int i) { return nextNbr(i, n); } //首个邻接顶点 virtual int nextNbr(int i, ...

  7. 步步为营(十六)搜索(二)BFS 广度优先搜索

    上一篇讲了DFS,那么与之相应的就是BFS.也就是 宽度优先遍历,又称广度优先搜索算法. 首先,让我们回顾一下什么是"深度": 更学术点的说法,能够看做"单位距离下,离起 ...

  8. 数据结构之 图论---基于邻接矩阵的广度优先搜索遍历(输出bfs遍历序列)

    数据结构实验图论一:基于邻接矩阵的广度优先搜索遍历 Time Limit: 1000MS Memory limit: 65536K 题目描述 给定一个无向连通图,顶点编号从0到n-1,用广度优先搜索( ...

  9. 关于宽搜BFS广度优先搜索的那点事

    以前一直知道深搜是一个递归栈,广搜是队列,FIFO先进先出LILO后进后出啥的.DFS是以深度作为第一关键词,即当碰到岔道口时总是先选择其中的一条岔路前进,而不管其他岔路,直到碰到死胡同时才返回岔道口 ...

随机推荐

  1. springboot-实现文件下载

    一 前言 本文实现的文件下载是使用Apache 的 commons-fileupload 实现:在之前的springboot系列文件中已经讲述过如何实现多文件上传:这篇文件实现的文件下载功能主要是能在 ...

  2. 开源工具abaplint的介绍

    长期以来,SAP提供的标准ABAP开发工具是我们对代码进行检查的唯一方式.这意味着我们只能对ABAP服务器上的ABAP代码做出分析,而离线代码则成为了纯粹的文本,开发者无法对其进行检查.abaplin ...

  3. Js 数组按数量分部!

    使用 reduce 将数组分为几个部分,每个部分最多10个! 相比其他语言使用 js  实现这个逻辑非常的简单方便! var group = function (source, step) { if ...

  4. js六种数据类型

    六种数据类型: undefined . boolean  .string .number .object .function 效果地址:https://scrimba.com/c/cEedDGTd 代 ...

  5. 求树上任意一点所能到达的最远距离 - 树上dp

    A school bought the first computer some time ago(so this computer's id is 1). During the recent year ...

  6. Java 方法重写方法重载

    1,方法的重载和方法的重写 方法名相同形参列表不通 方法名字的重新定义2,面向过程是分步骤解决问题 用方法组织代码 面向对象是以分类的方式解决问题 用类住址代码3 类是对对象的抽象 对象万事万物都是对 ...

  7. 曹工说Spring Boot源码(12)-- Spring解析xml文件,到底从中得到了什么(context:component-scan完整解析)

    写在前面的话 相关背景及资源: 曹工说Spring Boot源码(1)-- Bean Definition到底是什么,附spring思维导图分享 曹工说Spring Boot源码(2)-- Bean ...

  8. python爬虫——urllib使用代理

    收到粉丝私信说urllib库的教程还没写,好吧,urllib是python自带的库,没requests用着方便.本来嘛,python之禅(import this自己看)就说过,精简,效率,方便也是大家 ...

  9. 头条一面竟然问我Maven?

    maven package和maven install 有什么区别? 你常用的maven命令有哪些? <dependencyManagement> 是干什么的? 还有用过其它构建工具吗? ...

  10. [题解][Codeforces]Codeforces Round #602 (Div. 1) 简要题解

    orz djq_cpp lgm A 题意 给定一个分别含有 \(\frac n2\) 个左括号和右括号的括号序列 每次可以将序列的一个区间翻转 求一个不超过 \(n\) 次的操作方案,使得操作完之后的 ...