// exam1.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <iostream>
#include <stack>
using namespace std;
#define MAXVEX 20
#define INT_MAX 10000
typedef struct ArcNode
{
int adj;
void* info;
}ArcNode;
typedef ArcNode AdjMat[MAXVEX][MAXVEX];
typedef struct
{
int vexnum;
int arcnum;
AdjMat am;
}Graph;
void InitGraph(Graph& G)
{
cout<<"Please enter the number of vertex:"<<endl;
cin>>G.vexnum;
cout<<"Please enter the Arc of the graph:"<<endl;
cout<<"head tail weight"<<endl;
for(int i=0;i<G.vexnum;i++)
{
for(int j=0;j<G.vexnum;j++)
{
if(i==j)
{
G.am[i][j].adj=0;
}
else
{
G.am[i][j].adj=INT_MAX;
}
}
}
int vex1,vex2,w;
while(cin>>vex1>>vex2>>w)
{
G.am[vex1][vex2].adj=w;
}
}
void ShortestPath_FLOYD(Graph G,bool*** &path,int** &D)
{
path=(bool***)malloc(G.vexnum*sizeof(bool**));
for(int i=0;i<G.vexnum;i++)
{
path[i]=(bool**)malloc(sizeof(bool*)*G.vexnum);
}
for(int i=0;i<G.vexnum;i++)
{
for(int j=0;j<G.vexnum;j++)
{
path[i][j]=(bool*)malloc(G.vexnum*sizeof(bool));
}
}
D=(int**)malloc(G.vexnum*sizeof(int*));
for(int i=0;i<G.vexnum;i++)
{
D[i]=(int*)malloc(G.vexnum*sizeof(int));
}
for(int i=0;i<G.vexnum;i++)
{
for(int j=0;j<G.vexnum;j++)
{
D[i][j]=INT_MAX;
for(int k=0;k<G.vexnum;k++)
{
path[i][j][k]=false;
}
if(G.am[i][j].adj<INT_MAX)
{
D[i][j]=G.am[i][j].adj;
path[i][j][i]=true;
path[i][j][j]=true;
}
}
}
for(int k=0;k<G.vexnum;k++)
{
for(int i=0;i<G.vexnum;i++)
{
for(int j=0;j<G.vexnum;j++)
{
if(D[i][k]+D[k][j]<D[i][j])
{
D[i][j]=D[i][k]+D[k][j];
for(int m=0;m<G.vexnum;m++)
{
path[i][j][m]=path[i][k][m] || path[k][j][m];
}
}
}
}
}
}
void show_result(Graph G,bool***path,int**D)
{
cout<<"The distance matrix is:"<<endl;
for(int i=0;i<G.vexnum;i++)
{
for(int j=0;j<G.vexnum;j++)
{
cout<<D[i][j]<<" ";
}
cout<<endl;
}
cout<<"The path among nodes arw"<<endl;
for(int i=0;i<G.vexnum;i++)
{
for(int j=0;j<G.vexnum;j++)
{
cout<<"The path between v"<<i<<" and v"<<j<<" is:"<<endl;
for(int k=0;k<G.vexnum;k++)
{
cout<<path[i][j][k]<<" ";
}
cout<<endl<<"------------------------------------------------"<<endl;
}
}
}
int main(void)
{
Graph G;
InitGraph(G);
bool ***path;
int **D;
ShortestPath_FLOYD(G,path,D);
show_result(G,D);
system("pause");
return 0;
}
原文链接:https://www.f2er.com/datastructure/383018.html