第十三周项目3—Kijkstra算法

来源:互联网 发布:林书豪个人最佳数据 编辑:程序博客网 时间:2024/06/16 23:28
#include <stdio.h>#include <malloc.h>#include "graph.h"#define MaxSize 100void Ppath(int path[],int i,int v)  //前向递归查找路径上的顶点{    int k;    k=path[i];    if (k==v)  return;          //找到了起点则返回    Ppath(path,k,v);            //找顶点k的前一个顶点    printf("%d,",k);            //输出顶点k}void Dispath(int dist[],int path[],int s[],int n,int v){    int i;    for (i=0; i<n; i++)        if (s[i]==1)        {            printf("  从%d到%d的最短路径长度为:%d\t路径为:",v,i,dist[i]);            printf("%d,",v);    //输出路径上的起点            Ppath(path,i,v);    //输出路径上的中间点            printf("%d\n",i);   //输出路径上的终点        }        else  printf("从%d到%d不存在路径\n",v,i);}void Dijkstra(MGraph g,int v){    int dist[MAXV],path[MAXV];    int s[MAXV];    int mindis,i,j,u;    for (i=0; i<g.n; i++)    {        dist[i]=g.edges[v][i];      //距离初始化        s[i]=0;                     //s[]置空        if (g.edges[v][i]<INF)      //路径初始化            path[i]=v;        else            path[i]=-1;    }    s[v]=1;    path[v]=0;              //源点编号v放入s中    for (i=0; i<g.n; i++)               //循环直到所有顶点的最短路径都求出    {        mindis=INF;                 //mindis置最小长度初值        for (j=0; j<g.n; j++)       //选取不在s中且具有最小距离的顶点u            if (s[j]==0 && dist[j]<mindis)            {                u=j;                mindis=dist[j];            }        s[u]=1;                     //顶点u加入s中        for (j=0; j<g.n; j++)       //修改不在s中的顶点的距离            if (s[j]==0)                if (g.edges[u][j]<INF && dist[u]+g.edges[u][j]<dist[j])                {                    dist[j]=dist[u]+g.edges[u][j];                    path[j]=u;                }    }    Dispath(dist,path,s,g.n,v);     //输出最短路径}int main(){    MGraph g;    int A[7][7]=    {        {0,4,6,6,INF,INF,INF},        {INF,0,1,INF,7,INF,INF},        {INF,INF,0,INF,6,4,INF},        {INF,INF,2,0,INF,5,INF},        {INF,INF,INF,INF,0,INF,6},        {INF,INF,INF,INF,1,0,8},        {INF,INF,INF,INF,INF,INF,0}    };    ArrayToMat(A[0], 7, g);    Dijkstra(g,0);    return 0;}


0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 美图m6开不了机怎么办 美图m8开不开机怎么办 美图摄像头坏了怎么办 美图t8相机模糊怎么办 美图m4卡槽坏了怎么办 美图t8手机好卡怎么办 美图手机m6卡怎么办 美图t8屏幕不亮怎么办 美图m8卡机了怎么办 美图m6手机太卡怎么办 美图t8闪退怎么办 美图手机相机闪退怎么办 美图手机闪屏怎么办 魅族m6相册闪退怎么办 美图m6工厂模式怎么办 美图m6手机死机怎么办 美图m6s开不了机怎么办 美图手机m6进水怎么办 美图t8摔黑屏怎么办 美图屏幕点不动怎么办 朗动钥匙丢了怎么办 深圳小汽车摇号中签了怎么办 深圳摇号审核通过后怎么办 京东过保修期了怎么办 买的商业预付卡怎么办 壹钱包预付卡金额不足怎么办 美发店换老板原来预付卡怎么办 超市预付卡现超市停业怎么办? 利群购物卡丢了怎么办 利群金卡丢了怎么办 坐飞机洗漱用品超过规定怎么办 请律师团了解后怎么办 三星s9开不了机怎么办 三星手机开不了机了怎么办 安卓手机音响进水了怎么办 音响不读u盘怎么办 虎牌水壶显示f2怎么办 海尔冰箱门关不严没吸力怎么办 忘记京东金融账号怎么办 京东账号手机号已停用怎么办 京东账户忘了怎么办