欢迎观看我的博客,如有问题交流,欢迎评论区留言,一定尽快回复!(大家可以去看我的专栏,是所有文章的目录)
文章字体风格:
红色文字表示:重难点
蓝色文字表示:思路以及想法
上一篇,我们已经学过了【Dijkstra迪杰斯特拉算法+苦学两天所总结的逻辑】案例6-1.5 旅游规划
迪杰斯特拉算法,算得是一个图中,所有节点到一个头结点或者指定节点,的最短距离。接下来,我们要算,一个图中,所有点之间,每两点之间的最短距离,我们所应用的算法就是(弗洛伊德算法)
算法思路:
for(int k = 1 ; k <= n ; k ++)
{
for(int i = 1 ; i <= n ; i ++)
{
for(int j = 1 ; j <= n ; j ++)
{
if(e[i][j] > e[i][k] + e[k][j])
e[i][j] = e[i][k] + e[k][j];
}
}
}
#include
#define INT 0x3f3f3f3f
using namespace std;
int main()
{
int a,b,c[110][110],e,f,g,h,i,j,k,min=INT,max,n;
for(e=0;e<110;e++)//设初值
for(f=0;f<110;f++)
{
if(e==f)//初值自己变自己就是零喽
c[e][f]=0;
else
c[e][f]=INT;
}
cin>>a>>b;
while(b--)
{
cin>>e>>f>>g;
c[e][f]=c[f][e]=g;
}
for(k=1;k<=a;k++)//floyd算法
for(i=1;i<=a;i++)
for(j=1;j<=a;j++)
{
if(c[i][j]>c[i][k]+c[k][j])
c[i][j]=c[i][k]+c[k][j];
}
for(i=1;i<=a;i++)//行最高就是选该动物要变所有动物的最小花费
{
max=0;
for(j=1;j<=a;j++)
{
if(max<c[i][j])
max=c[i][j];
}
if(min>max)//比较选哪个动物咒语最短
{
n=i;
min=max;
}
}
if(min==INT)//如果min==TNT就说明无论选个动物都存在无法变的动物喽
cout<<"0"<<endl;
else
cout<<n<<' '<<min<<endl;
}