6-17 Shortest Path [4](25 分)
2018-02-25 12:42
260 查看
6-17 Shortest Path [4](25 分)
Write a program to find the weighted shortest distances from any vertex to a given source vertex in a digraph. If there is more than one minimum path from v to w, a path with the fewest number of edges is chosen. It is guaranteed that all the weights are positive and such a path is unique for any vertex.Format of functions:
void ShortestDist( MGraph Graph, int dist[], int path[], Vertex S );where
MGraphis defined as the following:
typedef struct GNode *PtrToGNode; struct GNode{ int Nv; int Ne; WeightType G[MaxVertexNum][MaxVertexNum]; }; typedef PtrToGNode MGraph;The shortest distance from
Vto the source
Sis supposed to be stored in
dist[V]. If
Vcannot be reached from
S, store -1 instead. If
Wis the vertex being visited right before
Valong the shortest path from
Sto
V, then
path[V]=W. If
Vcannot be reached from
S,
path[V]=-1, and we have
path[S]=-1.
Sample program of judge:
#include <stdio.h>
#include <stdlib.h>
typedef enum {false, true} bool;
#define INFINITY 1000000
#define MaxVertexNum 10 /* maximum number of vertices */
typedef int Vertex; /* vertices are numbered from 0 to MaxVertexNum-1 */
typedef int WeightType;
typedef struct GNode *PtrToGNode; struct GNode{ int Nv; int Ne; WeightType G[MaxVertexNum][MaxVertexNum]; }; typedef PtrToGNode MGraph;
MGraph ReadG(); /* details omitted */
void ShortestDist( MGraph Graph, int dist[], int path[], Vertex S );
int main()
{
int dist[MaxVertexNum], path[MaxVertexNum];
Vertex S, V;
MGraph G = ReadG();
scanf("%d", &S);
ShortestDist( G, dist, path, S );
for ( V=0; V<G->Nv; V++ )
printf("%d ", dist[V]);
printf("\n");
for ( V=0; V<G->Nv; V++ )
printf("%d ", path[V]);
printf("\n");
return 0;
}
/* Your function will be put here */
Sample Input (for the graph shown in the figure):
8 11 0 4 5 0 7 10 1 7 40 3 0 40 3 1 20 3 2 100 3 7 70 4 7 5 6 2 1 7 5 3 7 2 50 3
Sample Output:
40 20 100 0 45 53 -1 50 3 3 3 -1 0 7 -1 0作者: DS课程组单位: 浙江大学时间限制: 400ms内存限制: 64MB代码长度限制: 16KB
Vertex FindMin(int dist[], int Sure[], int N)
{
int i = 0, j = 0;
while (Sure[i] == 1 || dist[i] == INFINITY)
i++;
j = i + 1;
while (j < N) {
if (dist[i] > dist[j] && Sure[j] != 1) {
i = j;
return i;
}
else
j++;
}
if (i >= N)
return -1;
else
return i;
}
void ShortestDist(MGraph Graph, int dist[], int path[], Vertex S)
{
Vertex V = S;
int* Sure = (int*)malloc(Graph->Nv * sizeof(int));
memset(Sure, 0, Graph->Nv * sizeof(int));
for (int i = 0; i < MaxVertexNum; i++) {
dist[i] = INFINITY;
path[i] = -1;
}
Sure[V] = 1;
dist[V] = 0;
while (V != -1) {
for (Vertex i = 0; i < Graph->Nv; i++) {
if (Graph->G[V][i] != INFINITY && V != i) {
if (dist[i] != INFINITY) {
if (dist[i] > dist[V] + Graph->G[V][i]) {
dist[i] = dist[V] + Graph->G[V][i];
path[i] = V;
}
}
else {
dist[i] = dist[V] + Graph->G[V][i];
path[i] = V;
}
}
}
V = FindMin(dist, Sure, Graph->Nv);
if (V != -1)
Sure[V] = 1;
}
for (Vertex i = 0; i <Graph->Nv; i++)
if (dist[i] == INFINITY)
dist[i] = -1;
}
相关文章推荐
- 6-16 Shortest Path [3](25 分)
- 1126. Eulerian Path (25)
- OSPF(Open Shortest Path First)开放式最短路径优先协议01
- Bellman-ford algorithm to find the shortest path
- OSPF(Open Shortest Path First)开放式最短路径优先协议07
- hdu The Shortest Path in Nya Graph(建图+spfa)
- Codeforces Beta Round #3 A. Shortest path of the king
- VB工程17--百例25--古诗测试
- Enhanced IGRP(EIGRP) and Open Shortest Path First(OSPF)
- Shortest Path Faster Algorithm
- HDU 4725 The Shortest Path in Nya Graph(好题)
- ZOJ 2760 How Many Shortest Path (最小费用最大流做法)
- HDU 4725 —— The Shortest Path in Nya Graph
- Educational Codeforces Round 27-搜索&技巧&异或-G. Shortest Path Problem?
- Lecture 17 Shortest Paths I
- [ZOJ2760]How Many Shortest Path(floyd+最大流)
- NEFU要崛起——第2场 A - Shortest path of the king
- HDU Shortest path
- HDU4725 The Shortest Path in Nya Graph dij
- Open Shortest Path First; 内部网关协议之OSPF协议