| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 15918 人关注过本帖
标题:用迪杰斯特拉算法(Dijkstra)实现图的最短路径 C语言编写
只看楼主 加入收藏
韶志
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:斗气大陆
等 级:贵宾
威 望:44
帖 子:2223
专家分:13592
注 册:2013-3-22
结帖率:97.26%
收藏
已结贴  问题点数:100 回复次数:23 
用迪杰斯特拉算法(Dijkstra)实现图的最短路径 C语言编写
如题     我离散数学学的不是很好,望高手指点  
还有一点   要求实现可视化
搜索更多相关主题的帖子: C语言 离散数学 
2013-06-17 11:26
雪狼MJ
Rank: 8Rank: 8
来 自:甘肃
等 级:蝙蝠侠
威 望:4
帖 子:267
专家分:853
注 册:2012-5-27
收藏
得分:34 
程序代码:
#include <stdio.h>

/*
vertex 顶点 source 源点
path length 路径长度
pioneer 前驱
adjacent matrix 邻接矩阵
*/
#define MaxSize 5

#define Infinity 1000

void Dijkstra(int vertex, int source, int PathLength[], int AdjacentMatrix[MaxSize][MaxSize],int pioneer[MaxSize])
{
    //标记顶点是否在集合S中,如果是,则值为1,否为0
    bool sign[vertex];
   
    for(int i=0; i<vertex; i++)
    {
        //初始化源点到其他各个顶点的最短路径长度
        PathLength[i]=AdjacentMatrix[source][i];
       
        sign[i]=false;
       
        //满足条件,说明顶点i与源点不相邻
        if(PathLength[i]==Infinity)
        {
            pioneer[i]=-1;
           
        }
        else
        {
            pioneer[i]=source;
        }
       
    }
   
    //初始化时,集合S中只有一个元素,源点
    PathLength[source]=0;
    sign[source]=true;
   
    for(int i=0; i<vertex; i++)
    {
        int temp=Infinity;
       
        int t=source;
       
       
           
       
        for(int j=0; j<vertex; j++)
        {
            if((!sign[j]) && (PathLength[j]<temp))
            {
                t=j;
                temp=PathLength[j];
            }
        }
       
        if(t==source) break;
       
        sign[t]=true;
    
       
        for(int j=0; j<vertex; j++)
        {
            if((!sign[j]) && (AdjacentMatrix[t][j]!=Infinity))
            {
                if(PathLength[j]>(PathLength[t]+AdjacentMatrix[t][j]))
                {
                   
                    PathLength[j]=PathLength[t]+AdjacentMatrix[t][j];
                    pioneer[j]=t;
                }
            }
        }
   
    }
   
   
}

void find(int pineer[MaxSize], int i, int AdjacentMatrix[MaxSize][MaxSize])
{
    while(pineer[i]!=-1)
    {
        //反向的
        printf("(%d, %d)%d ", pineer[i], i, AdjacentMatrix[pineer[i]][i]);
        i=pineer[i];
    }
}

int main(void)
{
    int AdjacentMatrix[MaxSize][MaxSize]={Infinity,8,32,Infinity,Infinity,
                            12,Infinity,16,15,Infinity,
                            Infinity,29,Infinity,Infinity,13,
                            Infinity,21,Infinity,Infinity,7,
                            Infinity,Infinity,27,19,Infinity
                            };
    int vertex=MaxSize;
   
    int source=3;
   
    int PathLength[MaxSize];
   
    int pioneer[MaxSize];//记录前顶点
   
    for(int i=0; i<MaxSize; i++)
    {
        //初始化前顶点为无穷大
        pioneer[i]=Infinity;
    }
   
    printf("请输入源点(0~4):");
   
    scanf("%d", &source);
   
    printf("\n最短路径和长度\n");
   
    Dijkstra(vertex, source, PathLength, AdjacentMatrix, pioneer);
   
    for(int i=0; i<vertex; i++)
    {
        if(i==source) continue;
        
        printf("\n源点%d到顶点%d : %d ", source, i, PathLength[i]);
        find(pioneer, i, AdjacentMatrix);
        printf("\n");
    }
   
   
    return 0;
}

这是我不久前写的,图是固定的,用的是邻接矩阵,需要给出源点,然后会显示源点到各顶点的最短路径。

示例输出:
请输入源点(0~4):0

最短路径和长度

源点0到顶点1 : 8 (0, 1)8

源点0到顶点2 : 24 (1, 2)16 (0, 1)8

源点0到顶点3 : 23 (1, 3)15 (0, 1)8

源点0到顶点4 : 30 (3, 4)7 (1, 3)15 (0, 1)8
请按任意键继续. . .

楼主的可视化是什么意思?做个界面出来?有动画?


Edsger Dijkstra:算法+数据结构=程序
2013-06-17 12:28
韶志
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:斗气大陆
等 级:贵宾
威 望:44
帖 子:2223
专家分:13592
注 册:2013-3-22
收藏
得分:0 
回复 2楼 雪狼MJ
调试有错误哎...   要不你把你的测试结果截图给我
可视化就是界面啦

三十年河东,三十年河西,莫欺少年穷!
2013-06-17 12:40
雪狼MJ
Rank: 8Rank: 8
来 自:甘肃
等 级:蝙蝠侠
威 望:4
帖 子:267
专家分:853
注 册:2012-5-27
收藏
得分:0 
额,用C做界面,我还没搞过,你调试怎么错误了?贴出来看看

Edsger Dijkstra:算法+数据结构=程序
2013-06-17 14:41
雪狼MJ
Rank: 8Rank: 8
来 自:甘肃
等 级:蝙蝠侠
威 望:4
帖 子:267
专家分:853
注 册:2012-5-27
收藏
得分:0 
我的程序是没问题的~

Edsger Dijkstra:算法+数据结构=程序
2013-06-17 14:46
q1025518438
Rank: 2
等 级:论坛游民
帖 子:6
专家分:46
注 册:2013-6-11
收藏
得分:34 
百度上有   搜索迪杰斯特拉算法  在百度百科上
2013-06-17 14:58
韶志
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:斗气大陆
等 级:贵宾
威 望:44
帖 子:2223
专家分:13592
注 册:2013-3-22
收藏
得分:0 
回复 5楼 雪狼MJ
不对啊    你的bool型变量没有定义 啊

[ 本帖最后由 韶志 于 2013-6-17 16:59 编辑 ]

三十年河东,三十年河西,莫欺少年穷!
2013-06-17 16:46
雪狼MJ
Rank: 8Rank: 8
来 自:甘肃
等 级:蝙蝠侠
威 望:4
帖 子:267
专家分:853
注 册:2012-5-27
收藏
得分:0 
bool型变量没有定义????你逗我吗?bool型是内置的,我用的是C—Free4.0啊,你用的是什么高端的编译器?不会是turbo C吧??

Edsger Dijkstra:算法+数据结构=程序
2013-06-17 17:07
韶志
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:斗气大陆
等 级:贵宾
威 望:44
帖 子:2223
专家分:13592
注 册:2013-3-22
收藏
得分:0 
回复 8楼 雪狼MJ
我用的是VC6.0    C语言中没有布尔型啊   要使用的话应该枚举定义

三十年河东,三十年河西,莫欺少年穷!
2013-06-17 17:34
雪狼MJ
Rank: 8Rank: 8
来 自:甘肃
等 级:蝙蝠侠
威 望:4
帖 子:267
专家分:853
注 册:2012-5-27
收藏
得分:0 
我的C-Free就可以,它是内置的bool型,那你定义一下就好了,这不算什么问题的,就是编译器不同而已

Edsger Dijkstra:算法+数据结构=程序
2013-06-17 18:03
快速回复:用迪杰斯特拉算法(Dijkstra)实现图的最短路径 C语言编写
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.096268 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved