Floyed算法求最短路径及其长度矩阵和路径矩阵

本文介绍了使用Floyd算法解决数据结构中求最短路径问题,通过邻接矩阵进行存储,并详细阐述了初始化过程。实例展示了一个4x4的邻接矩阵,探讨了Dist矩阵中选用较大数值避免错误的重要性。
摘要由CSDN通过智能技术生成

这个是陈越数据结构第六章的习题6.12

构造了邻接矩阵存储,初始化时全部为零


#include<iostream>
using namespace std;
typedef int Vertex;
const int MaxVertexNum = 4;
typedef struct GNode * MGraph;
const int Infinity = 10;
int Dist[MaxVertexNum][MaxVertexNum], Path[MaxVertexNum][MaxVertexNum];
struct GNode {
	int Nv;
	int Ne;
	int G[MaxVertexNum][MaxVertexNum];
};
typedef struct ENode * Edge;
struct ENode {
	Vertex V1, V2;
	int Weight;
};
MGraph CreatGraph(int N)
{
	MGraph Graph = new struct GNode;
	Graph->Nv = N;
	Graph->Ne = 0;
	for (Vertex V = 0; V < Graph->Nv; V++)
		for (Vertex W = 0; W < Graph->Nv; W++)
			Graph->G[V][W] = 0;
	return Graph;
}
void Insert(MGraph Graph, Edge E)
{
	Graph->G[E->V1][E->V2] = E->Weight;
}
MGraph BuildGraph()
{
	int Nv;
	MGraph Graph;
	cin >> Nv;
	cin.get(
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值