图中两个点之间的路线

描述

给出一张有向图,设计一个算法判断两个点 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);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值