我的dijkstras算法有什么问题?
What is wrong with my dijkstras algorithm
我已经为此工作了几个小时,我非常沮丧。我不明白我做错了什么。
我使用Dijkstra的算法来查找源顶点之间的最短路径,以及使用邻接矩阵的其他4个顶点。这背后的想法是,有5个城市和往返的航班,我需要找到最便宜的机票价格,考虑到中途停留。
我正在遵循我的书中的算法,这是伪代码,以及以下网站上的代码:http://vinodcse.wordpress.com/2006/05/19/code-for-dijkstras-algorithm-in-c-2/
我遇到的问题是,在网站上嵌套的for循环中,计数器I从1开始,我相信这就是为什么从源顶点到所有顶点的距离都是正确的原因,除了第一个在999不变。
的例子:
当前距离:999 220 0 115 130
前任:0 3 0 2 2
所有这些距离都是正确的——即使我改变了源顶点——除了第一个保持不变。
如果我将计数器I改为0,它会打乱每段距离,即
电流距离: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++我的数学有什么问题,为什么我的代码不能正确循环
- 问题:什么是QAbstractItemView::NoEditTriggers的反面
- 当我尝试添加 2 个大字符串时,我无法弄清楚出了什么问题
- 违反const正确性:我应该现实地期待什么问题
- 这个带有模板<类 Vector 的C++代码片段有什么问题>
- 我的逻辑反转字符串中的元音有什么问题?
- 需要以下代码的帮助,下面的代码有什么问题
- 常量公共成员有什么问题?
- c++无值sort()的问题是什么?
- 以下代码中的函数模板有什么问题?
- 这个返回元素位置的基于循环的函数有什么问题?
- creat_list2功能有什么问题?
- 基本的 c++ 问题:如果我在函数中创建某些内容并返回它会发生什么?
- 我遇到了黑客排名中的问题"TWO STRINGS"的三个测试用例的分段错误。原因是什么?
- 什么是钻石问题?是一系列问题还是特定问题?
- 格式说明符C++有什么问题
- 我应该在 main 函数中写什么来测试我的问题?
- 任何人都可以告诉我我的 C++ 代码出了什么问题?
- 方法问题 - 什么会改变值,什么不会改变?什么是无效的?