鱼C论坛

 找回密码
 立即注册
查看: 3510|回复: 2

迪杰斯特拉算法求助

[复制链接]
发表于 2020-4-12 00:01:33 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
当k=1的时候会把v0-v3的最短路径设为8,当我往下走的时候发现改不了----小甲鱼的数据结构视频第65个视频的图(我好像等级太低放不了图。。。)程序如下




#define MAXVEX        9
#define        INFINITY        65535

typedef        int        Patharc[MAXVEX];                        // 用于存储最短路径下标的数组
typedef int        ShortPathTable[MAXVEX];                // 用于存储到各点最短路径的权值和

void ShortestPath_Dijkstar(MGraph G, int V0, Patharc *P, ShortPathTable *D)
{
        int v, w, k, min;
        int final[MAXVEX];                // final[w] = 1 表示已经求得顶点V0到Vw的最短路径
        
        // 初始化数据
        for( v=0; v < G.numVertexes; v++ )
        {
                final[v] = 0;                                // 全部顶点初始化为未找到最短路径
                (*D)[V] = G.arc[V0][v];                // 将与V0点有连线的顶点加上权值
                (*P)[V] = 0;                                // 初始化路径数组P为0
        }
        (*D)[V0] = 0;                // V0至V0的路径为0
        final[V0] = 1;                // V0至V0不需要求路径
        0
        // 开始主循环,每次求得V0到某个V顶点的最短路径
        for( v=1; v < G.numVertexes; v++ )
        {
                min = INFINITY;
                for( w=0; w < G.numVertexes; w++ )
                {
                        if( !final[w] && (*D)[w]<min )
                        {
                                k = w;
                                min = (*D)[w];
                        }
                }
                final[k] = 1;        // 将目前找到的最近的顶点置1
               
                // 修正当前最短路径及距离
                for( w=0; w < G.numVextexes; w++ )
                {
                        // 如果经过v顶点的路径比现在这条路径的长度短的话,更新!
                        if( !final[w] && (min+G.arc[k][w] < (*D)[w]) )
                        {
                                (*D)[w] = min + G.arc[k][w];        // 修改当前路径长度
                                (*p)[w] = k;                                        // 存放前驱顶点
                        }
                }
        }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-8-9 10:08:15 | 显示全部楼层
这个属实有问题,不知道怎么改
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-8-9 10:10:25 | 显示全部楼层
我做出来就是这样
D:    0     1       4        8       5        8         8        10        14
P:    0      0      1        1        2       4         3         6         7
F:    1      1      1        1        1       1         1         1         1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-7-4 23:08

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表