Java|Java 九宫重排(满分解法)
目录
- 题目
- 输入描述
- 输出描述
- 思路
题目 如下图的九宫格中,放着 1 ~ 8 的数字卡片,还有一个格子空着。与空格子相邻的格子中的卡片可以移动到空格中。 经过若干次移动,可以形成图 2 所示的局面。
文章图片
我们把上图的局面记为:12345678.
把下图的局面记为:123.46758
文章图片
【Java|Java 九宫重排(满分解法)】显然是按从上到下,从左到右的顺序记录数字,空格记为句点。
题目的任务是已知九宫的初态和终态,求最少经过多少步的移动可以到达。如果无论多少步都无法到达,则输出 -1。
输入描述 输入第一行包含九宫的初态,第二行包含九宫的终态。
输出描述 输出最少的步数,如果不存在方案,则输出 -1。
输入
12345678.输出
123.46758
3
思路 求最少步数,典型的广搜
- 题目让我们求最少步数,我们可以模拟空格的移动
- 通过字符串的下标交换字符位置,模拟字符串的上下左右的移动,每次移动通过set判断该状态是否已经移动过,如果没有就入队列
- 上(-3)下(+3)左(-1)右(+1)
- 判断每次的下标是否合法,越界只要判断示是否在字符串长度范围内
(pos%3 != index%3 && pos/3 != index/3)
因为当前位置和上下都只是差3,左右都只是差1
如果是左右就一定满足,下标/3相等
如果是上下就一定满足,下标%3相等
文章图片
代码
import java.util.*; public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in); String start = sc.next(); String end = sc.next(); // 枚举字符串下标的上下左右int[] upDownLeftRight = {-3,3,-1,1}; // 去重Set set = new HashSet<>(); Queue queue = new LinkedList<>(); set.add(start); queue.offer(start); int count = 0; // 标记是否已经找到boolean flag = false; while (!queue.isEmpty()) {int size = queue.size(); while (size-- != 0) {String s =queue.peek(); // 空格位置int index = s.indexOf("."); for (int i = 0; i < 4; i++) {int pos = index + upDownLeftRight[i]; // 当新的位置不是空格的上下左右或者已经越界if (pos < 0 || pos > 8 || (pos%3 != index%3 && pos/3 != index/3)) {continue; }char c = s.charAt(pos); char[] ch = s.toCharArray(); ch[pos] = ch[index]; ch[index] = c; String str = new String(ch); if (str.equals(end)) {flag = true; break; }if (set.add(str)) {queue.offer(str); }}queue.poll(); }count++; if (flag) {break; }}if (flag) {System.out.println(count); } else {System.out.println(-1); }}}
文章图片
到此这篇关于Java 九宫重排(满分解法)的文章就介绍到这了,更多相关Java 九宫重排内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- Java指令重排在多线程环境下的解决方式
- 如何使用Wavesurfer.js从JavaScript中的音频文件生成音频波(音频频谱)
- 如何从JavaScript中的2个值计算百分比变化(增加和减少)
- 使用Mousetrap在JavaScript中添加键盘快捷键的正确方法
- 你是否应该专门花时间学习Java编程语言()
- 如何在JavaScript中将图像合并为QR码
- 如何使用JavaScript突出显示Google地图中的区域(城市,州或国家/地区)
- 如何使用JavaScript从URL检索所有或特定的get参数
- 如何使用Remarkable将Markdown转换为JavaScript中的HTML
- 如何使用Java AWT创建和显示Windows 10通知