Leetcode773滑动谜题(BFS)
创始人
2025-05-31 20:30:47

题目链接

滑动谜题icon-default.png?t=N176https://leetcode.cn/problems/sliding-puzzle/如果对BFS不太了解,可以浏览下方的文章,对BFS有一个大致的了解:

BFS(迷宫问题)icon-default.png?t=N176https://blog.csdn.net/weixin_51882166/article/details/125891504

题目解析

题目:

在一个 2 x 3 的板上(board)有 5 块砖瓦,用数字 1~5 来表示, 以及一块空缺用 0 来表示。一次 移动 定义为选择 0 与一个相邻的数字(上下左右)进行交换.

最终当板 board 的结果是 [[1,2,3],[4,5,0]] 谜板被解开。

给出一个谜板的初始状态 board ,返回最少可以通过多少次移动解开谜板,如果不能解开谜板,则返回 -1 。

某一块板子的初始状态:

我们需要考虑,每次可以进行的操作是什么?

 每一层都可能会进行相应的操作,这种情况下考虑BFS。

我们的目标是:

现在的问题是,如何把二维数字简化,使得我们处理起来更简单?

首先,我们要做的是把二维数组拉平:

 

 

拉平后,如何找到每次进行的选择?

  根据上图,下标4的位置,可以做的选择有三种(1,3,5),由于规模是固定的,每个位置可以做的选择也是可以手算观察得到。如果空白块在0号位置,它能做的选择就只有两种,向下或者向右,(1,3),依次类推,得到空白块在所有位置所能移动的可能性:

 //空白块在每个位置,所能移动的位置static int[][] move = {{1, 3},{0, 4, 2},{1, 5},{0, 4},{1, 3, 5},{4, 2}};

为了便于处理,把拉长后的序列变成字符串,每次只需交换字符串里两个字符的位置,生成新字符即可:

 //交换空白块和其他块的位置static String swap(String s, int i, int j) {char[] c = s.toCharArray();char t = c[i];c[i] = c[j];c[j] = t;return new String(c);}

对于层序遍历,使用队列来进行,完整代码如下:

import java.util.HashSet;
import java.util.Queue;class Solution {//空白块在每个位置,所能移动的位置static int[][] move = {{1, 3},{0, 4, 2},{1, 5},{0, 4},{1, 3, 5},{4, 2}};//交换空白块和其他块的位置static String swap(String s, int i, int j) {char[] c = s.toCharArray();char t = c[i];c[i] = c[j];c[j] = t;return new String(c);}public int slidingPuzzle(int[][] board) {int m = 2, n = 3;//目标String target = "123450";//起点StringBuffer buf = new StringBuffer();for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {buf.append(board[i][j]);}}String start = buf.toString();int step = 0;Queue Q = new LinkedList();//set判重Set used = new HashSet<>();Q.add(start);used.add(start);while (!Q.isEmpty()) {int sz = Q.size();while (sz-- > 0) {String cur = Q.poll();if (cur.equals(target)) return step;//找到空格0的位置int idx = 0;while (cur.charAt(idx)!='0'){idx++;}//把空格所能走到的每一步加入队列,并且判重for (int next : move[idx]) {String nextS = swap(cur, idx, next);if (!used.contains(nextS)) {Q.add(nextS);used.add(nextS);}}}step++;}return -1;}
}

提交测试:

 

相关内容

热门资讯

最新!2025新势力5月销量出... 5月新势力表现如何?2025年5月的销售周期刚刚过去,不少造车新势力厂商的销量数据,已经新鲜出炉。数...
两家A股公司,收终止上市决定 又有两家A股上市公司收到股票终止上市决定,6月10日进入退市整理期。 上述自律监管决定书指出,因2...
重磅,事关教育强国,主力提前埋... 数据是个宝数据宝投资少烦恼这些产业的景气度处于上升期。《求是》杂志发表文章《加快建设教育强国》6月1...
阳光诺和“二刷”收购 80后富... 《投资者网》蔡俊时隔2年后,阳光诺和(688621.SH,下称“公司”)再拟收购同一个资产。实际上,...
买车,不安全了? 买车,不安全... 在新能源汽车市场竞争空前激烈的当下,车企、经销商习惯于采取更加激进的营销、市场策略,尤其在行业加速“...
欧佩克+同意7月再增产41.1... 为了增产惩罚超产国并争夺市场份额,欧佩克+连续第三个月大幅增产,美国页岩油生产商或首当其冲,美油一度...
经济学泰斗菲舍尔逝世:培育伯南... 当地时间6月1日,以色列央行发布声明称,世界著名经济学家、以色列央行前行长及美联储前副主席菲舍尔(S...
更名!“天府证券”来了 天府证... 【导读】宏信证券更名为天府证券中国基金报记者 吴君这家券商,历史上第二次更名。5月末,工商信息显示,...
两家A股公司,收终止上市决定 ... 又有两家A股上市公司收到股票终止上市决定,6月10日进入退市整理期。*ST鹏博(600804)公告称...
瑞幸降价迈入“6块9”时代?瑞... 说起最近几年的咖啡茶饮市场,相信每个人都不会陌生,各家咖啡茶饮企业的各种降价消息是此起彼伏,就在最近...
主次节奏:6.1黄金 - 每周... 本文每周初更新发布梳理各级别走势分析和预期主次节奏:做有品质的三方服务黄金月线图(超长线) 月线图...
超400亿资金狂涌!这类ETF... 债券ETF市场持续扩容。今年以来,债券市场表现震荡,债券类基金回报远不及预期,但这并未妨碍债券型ET...
坚定信心 行稳致远(记者手记) 侯琳良 最近一段时间,海尔集团上世纪90年代投资制作的《海尔兄弟》动画片,在多个视频平台上线高清重制...
世纪大辩论2——哈耶克与凯恩斯... 本来节后决定启动一个项目,但家里临时有事,需要陪家人去一趟北京,节后拉群的事,因此要推迟一周左右(具...
4月广州消费品市场表现强劲 1-4月,随着消费品以旧换新等促消费政策持续发力和各类会展活动陆续开展,政策相关消费快速增长,升级类...
金价,又跌了! 人民财讯5月31日电,5月30日,COMEX黄金期货收跌0.92%,报3313.1美元/盎司。 从高...
10万吨改性项目!巴斯夫、金发... 【DT新材料】获悉,6月3日,沪市主板新股海阳科技将启动申购,上市在即! 资料显示,海阳科技前身为南...
湾财周报|大事记 比亚迪驳斥“... 一周大事记(5月26日-6月1日) 头条 比亚迪驳斥! 长城“车圈恒大论”是行业警示还是危言耸听?...
通源石油跌1.96%,成交额1... 5月30日,通源石油跌1.96%,成交额1.03亿元,换手率4.40%,总市值23.54亿元。 异动...
中国邮储银行浙江分行2025校... 点这里 ↑ 老满说高考 作者 l 老满 生涯规划师l 升学顾问l 拆书家 这是 老满说高考公众号 的...
公募基金规模首次突破33万亿元... 每经记者:肖芮冬 每经编辑:叶峰 天赐良基日报第654期 一、今日基金新闻速览 1、华润元大基金贾...
湾财周报 大事记 比亚迪驳斥“... 一周大事记(5月26日-6月1日)头条比亚迪驳斥!长城“车圈恒大论”是行业警示还是危言耸听?近日,关...
EL表达式JSTL标签库 EL表达式     EL:Expression Language 表达式语言     ...
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
工信部、中汽协紧急发声!汽车“... 文/刘育英新一轮汽车价格战再起。近日,工信部、中汽协纷纷发声表示反对。工业和信息化部表示,将加大对汽...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
募资39亿,全亏光了,账上不到... 关于天然气,用户的感觉是价格一直在上涨,但很奇怪,不管怎么涨,天然气企业仍然亏,还亏得一塌糊涂。这是...
资阳房产评估公司 这是(tel-15828298733)整理的信息,希望能帮助到大家 在当今社会,随着经济的发展和城...
华桥汇利(中国)投资基金管理有... 今年第一季度,美国企业利润出现大幅下降,且面临着来自关税上升的持续压力,这一局面可能会在今年进一步加...
ESG 报告合规与鉴证:全球政... 在当下全球经济格局里,ESG(环境、社会和公司治理)已然成为衡量企业可持续发展能力的关键指标。随着全...