【id:111】【25分】A. DS图—图的最短路径(无框架)

题目描述

给出一个图的邻接矩阵,输入顶点v,用迪杰斯特拉算法求顶点v到其它顶点的最短路径。

输入

第一行输入t,表示有t个测试实例

第二行输入顶点数n和n个顶点信息

第三行起,每行输入邻接矩阵的一行,以此类推输入n行

第i个结点与其它结点如果相连则为距离,无连接则为0,数据之间用空格

隔开。第四行输入v0,表示求v0到其他顶点的最短路径距离

以此类推输入下一个示例

输出

对每组测试数据,输出:

每行输出v0到某个顶点的最短距离和最短路径

每行格式:v0编号-其他顶点编号-最短路径值----[最短路径]。没有路径输出:v0编号-其他顶点编号--1。具体请参考示范数据

输入输出样例

输入样例1 <-复制
2
5 0 1 2 3 4
0 5 0 7 15
0 0 5 0 0
0 0 0 0 1
0 0 2 0 0
0 0 0 0 0
0
6 V0 V1 V2 V3 V4 V5
0 0 10 0 30 100
0 0 5 0 0 0
0 0 0 50 0 0
0 0 0 0 0 10
0 0 0 20 0 60
0 0 0 0 0 0
V0


输出样例1
0-1-5----[0 1 ]
0-2-9----[0 3 2 ]
0-3-7----[0 3 ]
0-4-10----[0 3 2 4 ]
V0-V1--1
V0-V2-10----[V0 V2 ]
V0-V3-50----[V0 V4 V3 ]
V0-V4-30----[V0 V4 ]
V0-V5-60----[V0 V4 V3 V5 ]

AC代码

#include <iostream>
#include <string>
#define Max 1000
using namespace std;

class grath
{
	int n;
	int **juzhen;
	string *dian;
	string qi;
	string *path; //最短路径的字符串记录

public:
	grath()
	{
		cin >> n;
		dian = new string[n];
		path = new string[n];
		for (int i = 0; i < n; i++)
		{
			cin >> dian[i];
			juzhen = new int *[n];
		}
		for (int i = 0; i < n; i++)
		{
			juzhen[i] = new int[n];
			for (int j = 0; j < n; j++)
			{
				cin >> juzhen[i][j];
				if (juzhen[i][j] == 0)
					juzhen[i][j] = Max;
			}
		}
		cin >> qi;
	}

	int xun(string a)
	{
		int i;
		for (i = 0; i < n; i++)
			if (a == dian[i])
				return i;
	}

	void dij()
	{
		int i, j, minpos, min;
		bool *final = new bool[n]; //判断结点是否已找到最短路径
		int *Dest = new int[n];	  //最小路径的数组
		int index = xun(qi);
		for (int i = 0; i < n; i++) //初始化
		{
			path[i] = qi + " "; //记录路径
			Dest[i] = juzhen[index][i];
			final[i] = false;
		}
		Dest[index] = 0; //初始点最短路径为0 且已找到最短路径
		final[index] = true;
		for (i = 0; i < n - 1; i++) //进行n-1轮
		{
			min = Max;
			minpos = -1; //在Dest中未找到最短路径的顶点中路径最短顶点的下标
			for (j = 0; j < n; j++)
			{
				if (final[j] == false && min > Dest[j])
				{
					minpos = j;
					min = Dest[j];
				}
			}

			if (minpos != -1)
			{
				final[minpos] = true;
				path[minpos] += dian[minpos] + " "; //路径上加上这个点

				int q;
				for (q = 0; q < n; q++) //更新
				{
					if (final[q] == false && min + juzhen[minpos][q] < Dest[q])
					{
						Dest[q] = min + juzhen[minpos][q];
						path[q] = path[minpos];
					}
				}
			}
		}

		for (i = 1; i < n; i++)
		{
			cout << dian[0] << "-" << dian[i];
			if (Dest[i] >= Max)
			{
				cout << "--1" << endl;
				continue;
			}
			cout << "-" << Dest[i] << "----[" << path[i] << "]" << endl;
		}
	}
};

int main()
{
	int t;
	cin >> t; // 输入测试次数
	while (t--)
	{
		grath tu;
		tu.dij();
	}
}

该代码实现了一个图的类grath,其中包含了一个有向带权图的最短路径算法dij。通过输入测试次数和图的相关信息,进行多组测试。

在每组测试中,首先读取图的顶点个数和顶点的名称。然后根据顶点个数创建邻接矩阵,并将矩阵元素初始化为输入的权值。

接下来,读取起始顶点。然后,通过Dijkstra算法计算最短路径。最后,输出最短路径的结果。

(by 归忆) 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

归忆_AC

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值