您的位置:首页 > 编程语言 > Java开发

NYOJ 58 最少步数

2013-06-29 20:36 218 查看
最少步数

import java.util.Scanner;
public class Main {//广搜
static int a[][]={{1,1,1,1,1,1,1,1,1},
{1,0,0,1,0,0,1,0,1},
{1,0,0,1,1,0,0,0,1},
{1,0,1,0,1,1,0,1,1},
{1,0,0,0,0,1,0,0,1},
{1,1,0,1,0,1,0,0,1},
{1,1,0,1,0,1,0,0,1},
{1,1,0,1,0,0,0,0,1},
{1,1,1,1,1,1,1,1,1}
};
static int min;
static int x2,y2;
public static void main(String[] args) {
Scanner input=new Scanner(System.in);
int N=input.nextInt();
while(N-->0){
int x1=input.nextInt();
int y1=input.nextInt();
x2=input.nextInt();
y2=input.nextInt();
min=Integer.MAX_VALUE;
int num=0;
SouSuo(x1,y1,num);
System.out.println(min);
}
}
private static void SouSuo(int x1, int y1,int num) {
if(x1==x2&&y1==y2&&num<min){
min=num;
return;
}
if(a[x1][y1+1]==0){
a[x1][y1+1]=1;
SouSuo(x1,y1+1,num+1);
a[x1][y1+1]=0;
}
if(a[x1+1][y1]==0){
a[x1+1][y1]=1;
SouSuo(x1+1,y1,num+1);
a[x1+1][y1]=0;
}
if(a[x1-1][y1]==0){
a[x1-1][y1]=1;
SouSuo(x1-1,y1,num+1);
a[x1-1][y1]=0;
}
if(a[x1][y1-1]==0){
a[x1][y1-1]=1;
SouSuo(x1,y1-1,num+1);
a[x1][y1-1]=0;
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java NYOJ