hdu2833

/*
分析:
    floyd。
    显然,两条最短路径里面公共的那部分子路径一定
是连续的(如果一定要间断的话,那么说明有更短的路
径)。
    所以求出点两两之间的最短路,然后枚举每条路径,
看是否可以作为公共的那一部分。


                                               2013-03-08
*/








#include"stdio.h"
#include"string.h"
#include"stdlib.h"
#define N 311
int num[N][N];
int len[N][N];
int main()
{
	int n,m;
	int i,l,k,t;
	int s,e,dis;
	int a,b,c,d;
	while(scanf("%d%d",&n,&m),n||m)
	{
		memset(num,0,sizeof(num));
		for(i=1;i<=n;i++)
		{
			for(l=1;l<=n;l++)
			{
				if(i==l)	len[i][l]=0;
				else		len[i][l]=22222222;
			}
		}

		for(i=0;i<m;i++)
		{
			scanf("%d%d%d",&s,&e,&dis);
			if(len[s][e]<dis)	continue;
			len[s][e]=len[e][s]=dis;
			num[s][e]=num[e][s]=1;
		}

		for(k=1;k<=n;k++)
		{
			for(i=1;i<=n;i++)
			{
				for(l=1;l<=n;l++)
				{
					t=len[i][k]+len[k][l];
					if(t>len[i][l])	continue;
					if(t<len[i][l])
					{
						len[i][l]=t;
						num[i][l]=num[i][k]+num[k][l];
					}
					else if(num[i][k]+num[k][l]>num[i][l])
						num[i][l]=num[i][k]+num[k][l];
				}
			}
		}

		scanf("%d%d%d%d",&a,&b,&c,&d);
		int ans=-1;
		for(i=1;i<=n;i++)
		{
			for(l=1;l<=n;l++)
			{
				if(num[i][l]>ans
					&& (len[a][b]==len[a][i]+len[i][l]+len[l][b])
					&& (len[c][d]==len[c][i]+len[i][l]+len[l][d])
					)
					ans=num[i][l];
			}
		}
		printf("%d\n",ans+1);
	}
	return 0;
}


你可能感兴趣的:(hdu2833)