解题思路:
注意事项:
参考代码:
import java.util.Scanner;
public class Main {
static char a[][]=new char[3][3];//初始状态
private static int[][] b=new int [][]{{0,1},{1,0},{-1,0},{0,-1}};//四个移动方向
private static int[][] v=new int[10][10];
private static int count=0,min=Integer.MAX_VALUE;
private static char[][] c=new char[3][3];//存放最终状态
public static void main(String[] args) {
Scanner input=new Scanner(System.in);
String str=input.next();
String str2=input.next();
int x = 0,y = 0,k=0,endx=0,endy=0;//记录开始点的坐标,和最终点的坐标
for (int i= 0; i<3; i++) {
for (int j = 0; j<3; j++) {
a[i][j]=str.charAt(k++);
if(a[i][j]=='.'){
x=i;
y=j;
}
}
}
k=0;
for (int i= 0; i<3; i++) {
for (int j = 0; j<3; j++) {
c[i][j]=str2.charAt(k++);
if(c[i][j]=='.'){
endx=i;
endy=j;
}
}
}
dfs(x,y,endx,endy);
if(min==Integer.MAX_VALUE)System.out.println(-1);
else
System.out.println(min);
}
private static void dfs(int x, int y, int endx, int endy) {
if(x==endx&&y==endy){//如果“.“走到最终状态位置
if(check()){//判断是否与终太一样
if(min>=count)min=count;//记录最少步数
}
return;
}else
for (int i = 0; i <4; i++) {
if(b[i][0]+x<3&&b[i][0]+x>=0&&b[i][1]+y<3&&b[i][1]+y>=0&&v[b[i][0]+x][b[i][1]+y]==0){//未走过且没有出边界
v[x][y]=1;//标记以走
count++;//步数加一
char k=a[x][y];//交换位置
a[x][y]=a[b[i][0]+x][b[i][1]+y];
a[b[i][0]+x][b[i][1]+y]=k;
dfs(b[i][0]+x,b[i][1]+y,endx,endy);
count--;
k=a[x][y];
a[x][y]=a[b[i][0]+x][b[i][1]+y];
a[b[i][0]+x][b[i][1]+y]=k;
v[x][y]=0;
}
}
}
private static boolean check() {
for (int i= 0; i<3; i++) {
for (int j = 0; j<3; j++) {
if(a[i][j]!=c[i][j])return false;
}
}
return true;
}
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复