当前位置: 首页 > backend >正文

蓝桥杯 4. 卡片换位

卡片换位

原题目链接

题目描述

你玩过华容道的游戏吗?

这是一个类似的,但更简单的游戏。

看下面的 3 × 2 格子:

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

在其中放置了 5 张牌,其中:

  • A 表示关羽,
  • B 表示张飞,
  • * 表示士兵,
  • 空格表示空位。

你可以将一张牌移动到相邻的空格中(对角线不算相邻)。

游戏目标是:让关羽和张飞交换位置,其他牌的位置可以随意。


输入描述

输入两行,每行包含 3 个字符,表示当前局面。

字符说明:

  • A:关羽
  • B:张飞
  • *:士兵
  • (空格):空位

输出描述

输出一个整数,表示最少多少步可以完成关羽与张飞的位置交换。


输入输出样例

示例

输入

* A
**B

输出

17

(注:要求最少移动步数达成目标,其他牌随意。)

c++代码

#include<bits/stdc++.h>using namespace std;string a, b;
int l_A, l_B;
unordered_set<string> mp;class solution{
public:int k, l_A, l_B;long long ans;solution() { this->ans = 0; }
};long long bfs() {vector<vector<int>> arr = { {1, 3}, {0, 2, 4}, {1, 5}, {0, 4}, {3, 5, 1}, {4, 2} };string c = a + b;solution s, mid;for (int i = 0; i < 6; i++) {if (c[i] == ' ') s.k = i;else if (c[i] == 'A') l_A = i, s.l_A = i;else if (c[i] == 'B') l_B = i, s.l_B = i;}queue<solution> qu;qu.push(s);while(!qu.empty()) {s = qu.front(), qu.pop();string temp = to_string(s.k) + " " + to_string(s.l_A) + " " + to_string(s.l_B);if (mp.find(temp) != mp.end()) continue;mp.insert(temp);if (s.l_A == l_B && s.l_B == l_A) return s.ans;for (int x : arr[s.k]) {mid = s;mid.k = x, mid.ans++;if (mid.l_A == x) mid.l_A = s.k;if (mid.l_B == x) mid.l_B = s.k;qu.push(mid);}}return -1;
}int main() {getline(cin, a);getline(cin, b);cout << bfs();return 0;
}//by wqs

题目解析

纯纯暴力BFS题目

http://www.xdnf.cn/news/1947.html

相关文章:

  • txtai:全能AI框架
  • 龙虎榜——20250425
  • spreadsheet 之websheet
  • vue项目前后端分离设计
  • 从氛围到节奏:情绪化配乐网站指南
  • 【Harmony_Bug】forEach + asyncawait 的异步陷阱
  • assertEquals()
  • 基于AIGC的3D场景生成实战:从文本描述到虚拟世界构建
  • 脚本分享:快速作图对比wannier拟合能带python脚本
  • 产品动态|千眼狼sCMOS科学相机捕获单分子荧光信号
  • Java代理讲解
  • 常见网络安全攻击类型深度剖析(三):DDoS攻击——分类、攻击机制及企业级防御策略
  • AI编程:[体验]从 0 到 1 开发一个项目的初体验
  • 利用车联网中的 V2V 通信技术传播公平的紧急信息
  • 【深度强化学习 DRL 快速实践】异步优势演员评论员算法 (A3C)
  • PCIe具体解释分析
  • 【基础IO上】复习C语言文件接口 | 学习系统文件接口 | 认识文件描述符 | Linux系统下,一切皆文件 | 重定向原理
  • 【kafka初学】启动执行命令
  • c#操作excel表格
  • Java与Kotlin在Android开发中的全面对比分析
  • 【Luogu】动态规划四
  • Hot100方法及易错点总结2
  • firewalld 详解
  • 微信小程序蓝牙连接打印机打印单据完整Demo【蓝牙小票打印】
  • 【prompt是什么?有哪些技巧?】
  • Linux操作系统复习
  • 3D模型文件格式之《STL格式介绍》
  • SSH服务介绍
  • string的基本使用
  • uniapp自定义封装tabbar