你好我已经在C Dijkstra的算法中实现了找到最短路径,但是我需要返回n个最短路径,任何人都有一个想法我该怎么做。如何返回n最佳最短路径(dijkstra算法)
我的Dijkstra功能:
int * Dijkstra(graph **g, int totalVertex, int vStart) {
int i;
int *distance = (int*) malloc(totalVertex * sizeof (int));
int *last = (int*) malloc(totalVertex * sizeof (int));
int *visited = (int*) calloc(totalVertex, sizeof (int));
int maxDistance, m;
graph *vertex;
for (i = 0; i < totalVertex; i++) {
distance[i] = MAXINT;
last[i] = -1;
}
distance[vOrigem] = 0;
while (sum(visited, totalVertex) < totalVertex) {
maxDistance = MAXINT;
for (i = 0; i < totalVertex; i++) {
if ((distance[i] < maxDistance) && (visited[i] == 0)) {
maxDistance = distance[i];
m = i;
}
}
vertex = g[m];
while (vertex != NULL) {
if ((vertex->distance + distance[m]) < (distance[vertex-> destination])) {
distance[vertex->destination] = vertex->distance + distance[m];
last[vertex->destination] = m;
}
vertex = vertice->next;
}
visited[m] = 1;
}
free(distance);
free(visited);
return last;
}
我需要调用如2倍这个函数并返回,图中的两个最短路径。
谢谢。
这是一个功课问题吗? – gcbenison
不,不是,我正在寻找迪杰斯特拉,我不是在问一个解决方案,只是一些想法,我该怎么做。 –
迭代运行Dijstra,每次删除解决方案的顶点。 – tbert