描述
给出一张有向图,设计一个算法判断两个点 s
与 t
之间是否存在路线。
您在真实的面试中是否遇到过这个题? 是
题目纠错
样例
如下图:
A----->B----->C
\ |
\ |
\ |
\ v
->D----->E
样例 1:
输入:s = B and t = E,
输出:true
样例 2:
输入:s = D and t = C,
输出:false
使用Floyd佛洛依德最短路径算法实现
Scanner scanner=new Scanner(System.in);
int inf=99999;
int a[][]=new int[5][5];
int i,j;
for( i=0;i<5;i++)
for( j=0;j<5;j++)
if(i==j)
a[i][j]=0;
else
a[i][j]=inf;//正无穷
String n,m;
n=scanner.next();
m=scanner.next();
//有向图
//建立城市之间的联系
a[0][1]=1; //A->B
a[1][2]=1; //B->C
a[0][3]=1; //A->C
a[1][3]=1; //B->D
a[3][4]=1; //D->E
//核心算法
for(int k=0;k<5;k++)
for( i=0;i<5;i++) {
for( j=0;j<5;j++)
if(a[i][k]<inf&&a[k][j]<inf)
a[i][j]=a[i][k]+a[k][j];
}
int n1=n.charAt(0)-65;
int m1=m.charAt(0)-65;
System.out.println("\n\n");
//打印城市之间的联系图
for(int k=0;k<5;k++) {
for( i=0;i<5;i++)
System.out.print(a[k][i]+" ");
System.out.println();
}
System.out.println("\n\n");
if(a[n1][m1]>0&&a[n1][m1]<inf)
System.out.println(true);
else
System.out.println(false);