数据结构:最短路径(Dijkstra c++实现)

数据结构:最短路径(Dijkstra c++实现)_第1张图片

数据结构:最短路径(Dijkstra c++实现)_第2张图片

数据结构:最短路径(Dijkstra c++实现)_第3张图片


#include 
#include 
#include 
#include 
using namespace std;

#define MAXSIZE 10  //顶点最大个数
typedef string VertexType; //顶点类型
typedef int EdgeType;  //权值类型,有向图(0,1),无向图(权值,无穷大)
#define INFINITY 0xffff
typedef struct  
{
	VertexType Vexs[MAXSIZE];  //顶点向量
	EdgeType arcs[MAXSIZE][MAXSIZE]; //邻接矩阵,可看作为边表
	int iVexNum;  //顶点个数
	int iArcNum;  //边数
}MGraph;
#define SUCCESS 1
#define UNSUCCESS 0
typedef int Status;

//由顶点值得到顶点索引
int GetIndexByVertexVal( const MGraph& MG, VertexType val )
{
	for ( int i = 0; i < MG.iVexNum; ++i )
	{
		if ( val == MG.Vexs[i] )
			return i;
	}
	return -1;
}


//创建无向图
Status CreateGraph( MGraph& MG )
{
	cout << "输入顶点个数以及边数:";
	cin >> MG.iVexNum >> MG.iArcNum;
	cout << "请输入" << MG.iVexNum << "个顶点:";
	for ( int i = 0; i < MG.iVexNum; ++i )
	{
		cin >> MG.Vexs[i];
	}

	for ( int i = 0; i < MG.iVexNum; ++i )
	{
		for ( int j = 0; j < MG.iVexNum; ++j )
		{
			MG.arcs[i][j] = INFINITY;
		}
	}

	cout << "请输入由两点构成的边及其权值:";
	for ( int i = 0; i < MG.iArcNum; ++i )
	{
		VertexType first;
		VertexType second;
		EdgeType weight;
		cin >> first >> second >> weight;
		int m = GetIndexByVertexVal( MG, first );
		int n = GetIndexByVertexVal( MG, second ); 
		if ( m == -1 || n == -1 )
			return UNSUCCESS;

		MG.arcs[m][n] = MG.arcs[n][m] = weight;
	}

	return SUCCESS;
}


//迪杰斯特拉算法(Dijkstra)求最短径
//从v0开始,找到到各个点的最短路径长
//pathMatrix保存了路径信息,比如pathMatrix[3] = 4,表示v3的前趋为v4
//pathTable[i]保存了v0-->vi的路径长度
typedef int PathMatrix;
typedef int ShortPathTable;
void ShorttestPath_Dijkstra( const MGraph& G, int v0, 
							PathMatrix *pathMatrix, ShortPathTable* pathTable )
{
	int final[MAXSIZE]; //指示已找到最短路径的顶点
	memset( final, 0, sizeof(final) );

	for ( int i = 0; i < G.iVexNum; ++i )
	{
		final[i] = 0;
		pathTable[i] = G.arcs[v0][i];
		pathMatrix[i] = v0;  //前趋
	}

	final[v0] = 1; //v0本身,不需要求
	pathMatrix[v0] = 0;
	pathTable[v0] = v0;

	
	for ( int i = 1; i < G.iVexNum; ++i )//主循环,求v0到各个顶点的最短路径
	{
		int min = INFINITY;
		int k = 0;
		for ( int j = 0; j < G.iVexNum; ++j )
		{
			if ( !final[j] && min > pathTable[j] )
			{
				min = pathTable[j];
				k = j;
			}
		}
		final[k] = 1;

		//重新调整当前到各个点的最短路径长
		for ( int j = 0; j < G.iVexNum; ++j )
		{
			if ( !final[j] && (G.arcs[k][j] + min ) < pathTable[j] )
			{
				pathTable[j] = G.arcs[k][j] + min;
				pathMatrix[j] = k;  //修改当前点的前趋
			}
		}
	}

}

//打印出到各点的最短路径结果
void PrintShortestPath( int v0, int iVexNum, const PathMatrix *pathMatrix,
					   const ShortPathTable* pathTable )
{
	for ( int i = 1; i < iVexNum; ++i )
	{
		deque pathTemp;
		int k = i;
		pathTemp.push_front( k );
		while ( pathMatrix[k] != v0 )
		{
			pathTemp.push_front( pathMatrix[k] );
			k = pathMatrix[k];
		}

		cout << "V" << v0 << "-->";
		for ( int j = 0; j < (int)pathTemp.size(); ++j )
		{
			cout << "V" << pathTemp[j] << "-->";
		}
		cout << "NULL" << "路径长为:" << pathTable[i] << endl;
	}
}


int main()
{
	MGraph MG;
	CreateGraph( MG );
 
	//迪杰斯特拉算法求最短路径(Dijkstra)
	PathMatrix pathMatrix[MAXSIZE];
	ShortPathTable pathTable[MAXSIZE];
	int v0 = 0;
	ShorttestPath_Dijkstra( MG, v0, pathMatrix, pathTable );
	PrintShortestPath( v0, MG.iVexNum, pathMatrix, pathTable );//打印出到各点的最短路径结果

	return 0;
}

数据结构:最短路径(Dijkstra c++实现)_第4张图片

你可能感兴趣的:(数据结构)