gpt4 book ai didi

c++ - 我的 dijkstra 算法有什么问题

转载 作者:行者123 更新时间:2023-11-28 08:13:33 27 4
gpt4 key购买 nike

所以我已经为此工作了几个小时,我感到非常沮丧。我不明白我做错了什么。

我正在使用 Dijkstra 算法使用邻接矩阵查找源顶点和其他 4 个顶点之间的最短路径。这背后的想法是,有 5 个城市和往返它们的航类,我需要找到最便宜的机票价格,同时考虑到中途停留。

我遵循我书中的算法,它是伪代码,以及以下网站上的代码:http://vinodcse.wordpress.com/2006/05/19/code-for-dijkstras-algorithm-in-c-2/

我遇到的问题是,在网站的嵌套 for 循环中,计数器 i 从 1 开始,我相信这就是源顶点到所有顶点的距离的原因都是正确的,除了第一个没有变化,仍然是 999。

例子:

Current Distance: 999 220 0 115 130

Predecessors: 0 3 0 2 2

所有这些距离都是正确的——即使我改变了源顶点——除了第一个保持不变。

如果我将计数器 i 更改为 0,它会弄乱每个距离,即

Current Distance: 0 105 0 0 0

无论如何,请帮忙。这是相关代码。

void Graph::findDistance(int startingVertex)
{
for(int i=0; i<MAX;i++)
{
currentDistance[i] = 999;
toBeChecked[i] = 1;
predecessor[i] = 0;
}

currentDistance[startingVertex]=0;
bool flag=true;
int v;
while(flag)
{
v=minimum();

toBeChecked[v]=0;

for(int i=1; i<MAX;i++) //here is where i think im going wrong
{
if(adjecencyMatrix[v][i]>0)
{
if(toBeChecked[i]!=0)
{
if(currentDistance[i] > currentDistance[v]+adjecencyMatrix[v][i][0].ticketPrice)
{
currentDistance[i] = currentDistance[v]+adjecencyMatrix[v][i][0].ticketPrice;
predecessor[i]=v;
}
}
}
}

flag = false;
for(int i=1; i<MAX;i++)
{
if(toBeChecked[i]==1)
flag=true;
}
}
}

int Graph::minimum()
{
int min=999;
int i,t;
for(i=0;i<MAX;i++)
{
if(toBeChecked[i]!=0)
{
if(min>=currentDistance[i])
{
min=currentDistance[i];
t=i;
}
}
}
return t;
}

最佳答案

不应该检查

  if(adjecencyMatrix[v][i]>0)   

像其他比较一样,用 adjecencyMatrix[v][i][0].ticketPrice 完成吗?

如果 adjecencyMatrix[v][i] 是一个数组,它将被转换为一个指针,并且该指针将始终大于 0。数组到指针的衰减再次发生 :)

关于c++ - 我的 dijkstra 算法有什么问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8380920/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com