第四届蓝桥杯决赛题-九宫重排(双向广搜).java

2023-11-21 15:40

本文主要是介绍第四届蓝桥杯决赛题-九宫重排(双向广搜).java,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述
如下面第一个图的九宫格中,放着 1~8 的数字卡片,还有一个格子空着。与空格子相邻的格子中的卡片可以移动到空格中。经过若干次移动,可以形成第二个图所示的局面。

  我们把第一个图的局面记为:12345678.
  把第二个图的局面记为:123.46758
  显然是按从上到下,从左到右的顺序记录数字,空格记为句点。
  本题目的任务是已知九宫的初态和终态,求最少经过多少步的移动可以到达。如果无论多少步都无法到达,则输出-1。
输入格式
输入第一行包含九宫的初态,第二行包含九宫的终态。
输出格式
输出最少的步数,如果不存在方案,则输出-1。
样例输入
12345678.
123.46758
样例输出
3
样例输入
13524678.
46758123.
样例输出
22

/** 132757	张燚	九宫重排	  2014-03-08 21:56	5.209KB	JAVA	正确	 100	156ms	33.90MB	评测详情  * * */
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.Queue;
public class Main{//双向广搜private static HashMap<String,Integer> hm1=null,hm2=null;public static void main(String[] args) {BufferedReader bf=new BufferedReader(new InputStreamReader(System.in));try {String start=bf.readLine();String end=bf.readLine();char a[][]=new char[3][3];char b[][]=new char[3][3];int c=0;int x1=0,y1=0,x2=0,y2=0;for(int i=0;i<3;i++){for(int j=0;j<3;j++){a[i][j]=start.charAt(c);b[i][j]=end.charAt(c);if(a[i][j]=='.'){x1=i;y1=j;}if(b[i][j]=='.'){x2=i;y2=j;}c++;}}Node node1=new Node(a,0,x1,y1);Node node2=new Node(b,0,x2,y2);Queue<Node> q1=new LinkedList<Node>();Queue<Node> q2=new LinkedList<Node>();hm1=new HashMap<String, Integer>();hm2=new HashMap<String, Integer>();hm1.put(start, 0);hm2.put(end, 0);q1.add(node1);q2.add(node2);System.out.println(bfs(q1,q2));} catch (IOException e) {e.printStackTrace();}}private static int bfs(Queue<Node> q1,Queue<Node> q2) {while(!q1.isEmpty()||!q2.isEmpty()){if(!q1.isEmpty()){Node node1=q1.poll();//	System.out.println(node1.getTuString()+"----1");if(hm2.containsKey(node1.getTuString())){return node1.getSum()+hm2.get(node1.getTuString());}int x=node1.getX();int y=node1.getY();if(x>0){char a[][]=node1.getTuCopy();a[x][y]=a[x-1][y];a[x-1][y]='.';Node n=new Node(a,node1.getSum()+1,x-1,y);String s=n.getTuString();if(hm2.containsKey(s)){return n.getSum()+hm2.get(s);}if(!hm1.containsKey(s)){hm1.put(s, n.getSum());q1.add(n);}}if(x<2){char a[][]=node1.getTuCopy();a[x][y]=a[x+1][y];a[x+1][y]='.';Node n=new Node(a,node1.getSum()+1,x+1,y);String s=n.getTuString();if(hm2.containsKey(s)){return n.getSum()+hm2.get(s);}if(!hm1.containsKey(s)){hm1.put(s, n.getSum());q1.add(n);}}if(y>0){char a[][]=node1.getTuCopy();a[x][y]=a[x][y-1];a[x][y-1]='.';Node n=new Node(a,node1.getSum()+1,x,y-1);String s=n.getTuString();if(hm2.containsKey(s)){return n.getSum()+hm2.get(s);}if(!hm1.containsKey(s)){hm1.put(s, n.getSum());q1.add(n);}}if(y<2){char a[][]=node1.getTuCopy();a[x][y]=a[x][y+1];a[x][y+1]='.';Node n=new Node(a,node1.getSum()+1,x,y+1);String s=n.getTuString();if(hm2.containsKey(s)){return n.getSum()+hm2.get(s);}if(!hm1.containsKey(s)){hm1.put(s, n.getSum());q1.add(n);}}}if(!q2.isEmpty()){Node node2=q2.poll();//	System.out.println(node2.getTuString()+"----2");if(hm1.containsKey(node2.getTuString())){return node2.getSum()+hm1.get(node2.getTuString());}int x=node2.getX();int y=node2.getY();if(x>0){char a[][]=node2.getTuCopy();a[x][y]=a[x-1][y];a[x-1][y]='.';Node n=new Node(a,node2.getSum()+1,x-1,y);String s=n.getTuString();if(hm1.containsKey(s)){return n.getSum()+hm1.get(s);}if(!hm2.containsKey(s)){hm2.put(s, n.getSum());q2.add(n);}}if(x<2){char a[][]=node2.getTuCopy();a[x][y]=a[x+1][y];a[x+1][y]='.';Node n=new Node(a,node2.getSum()+1,x+1,y);String s=n.getTuString();if(hm1.containsKey(s)){return n.getSum()+hm1.get(s);}if(!hm2.containsKey(s)){hm2.put(s, n.getSum());q2.add(n);}}if(y>0){char a[][]=node2.getTuCopy();a[x][y]=a[x][y-1];a[x][y-1]='.';Node n=new Node(a,node2.getSum()+1,x,y-1);String s=n.getTuString();if(hm1.containsKey(s)){return n.getSum()+hm1.get(s);}if(!hm2.containsKey(s)){hm2.put(s, n.getSum());q2.add(n);}}if(y<2){char a[][]=node2.getTuCopy();a[x][y]=a[x][y+1];a[x][y+1]='.';Node n=new Node(a,node2.getSum()+1,x,y+1);String s=n.getTuString();if(hm1.containsKey(s)){return n.getSum()+hm1.get(s);}if(!hm2.containsKey(s)){hm2.put(s, n.getSum());q2.add(n);}}}}return -1;}
}
class Node{char tu[][]=new char[3][3];int sum=0;int x=0,y=0;public Node(char[][] tu, int sum, int x, int y) {super();this.tu = tu;this.sum = sum;this.x = x;this.y = y;}public char[][] getTuCopy() {char a[][]=new char[3][3];for(int i=0;i<3;i++)for(int j=0;j<3;j++)a[i][j]=tu[i][j];return a;}public String getTuString() {StringBuffer sb=new StringBuffer("");for(int i=0;i<3;i++)for(int j=0;j<3;j++)sb.append(tu[i][j]);return sb.toString();}public void setTu(char[][] tu) {this.tu = tu;}public int getSum() {return sum;}public void setSum(int sum) {this.sum = sum;}public int getX() {return x;}public void setX(int x) {this.x = x;}public int getY() {return y;}public void setY(int y) {this.y = y;}
}




这篇关于第四届蓝桥杯决赛题-九宫重排(双向广搜).java的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/403308

相关文章

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B