如何简单方便的求出图中任意两点的最短路径
Floyd-Warshall算法(O(n)比较适用于边较多的稠密图(Dense Graph))
int n,m,d[100][100];//点数,边数,邻接矩阵
scanf("%d%d",&n,&m);
memset(d,INF,sizeof(d));//初始化邻接矩阵
for(int i=1;i<=n;i++){
d[i][i]=0;
}
for(int i=1;i<=m;i++){
scanf("%d%d%d",&a,&b,&c);//边的信息
d[a][b]=c;
//d[b][a]=c 无向图调用
}
for(int k=1;k<=n;k++){
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(d[i][k]<INF&&d[k][j]<INF){ //判断是否能从松弛点到达
d[i][j]=min(d[i][j],d[i][k]+d[k][j]);
}
}
}
}