皮皮网

【酷狗点歌源码】【玖富钱包源码】【湖南共享店铺源码】dijkstra算法源码_dijkstra算法 代码

时间:2025-01-23 17:43:14 来源:dnf源码再哪

1.c语言编写路线
2.求一个道客巴巴免费账号,算法算法下载文章http://www.doc88.com/p-040673379552.html

dijkstra算法源码_dijkstra算法 代码

c语言编写路线

       #include <stdio.h>

       #include <malloc.h>

       #include<stdlib.h>

       #define MAX

       #define MAXNUM

       int previous[MAX-1];// 求路径需要

       int pp[MAX-1];// 记录最短路径

       typedef struct graphnode

       {

        int vexnum; //顶点

        int arcnum; //弧

        int gra[MAX][MAX]; //邻接矩阵表示0或1

       }Graph;

       int dist[MAX]; // 最短距离

       int arc[MAX][MAX]; // 权

       int main()

       {

        void Dijkstra(Graph *g,源码int v);

        int i,j,n,m;

        int v; //源点

        Graph *G;

        G=(Graph *)malloc(sizeof(Graph));

        printf("vexnum:\n");

        scanf("%d",&G->vexnum);

        printf("arcnum:\n");

        scanf("%d",&G->arcnum);

        printf("graph:\n");

        for(i=0;i<G->vexnum;i++)

        for(j=0;j<G->vexnum;j++)

        {

        scanf("%d",&G->gra[i][j]);

        }

        for(i=0;i<G->vexnum;i++)

        for(j=0;j<G->vexnum;j++)

        {

        if(G->gra[i][j]==1)

        {

        printf("请输入%d到%d的权值:",i,j);

        scanf("%d",&arc[i][j]);//若有弧 则输入i到j直接的权

        }

        else

        arc[i][j]=MAXNUM;

        }

        printf("请输入源点v的值:");

        scanf("%d",&v);

        Dijkstra(G,v);

        printf("请输入源点所要到达的点:\n");

        scanf("%d",&n);

        pp[0]=0;

        i=1;

        m=n;// 记录n的值

        while(n!=0)// 求0到其他点路径

        {

        pp[i]=previous[n];

        i++;

        n=previous[n];

        }

        printf("Path:0 -> ");

        for(j=G->vexnum-1;j>=0;j--)

        if(pp[j]!=0)

        printf(" %d -> ",pp[j]);

        printf("%d\n",m);

        return 0;

       }

       void Dijkstra(Graph *G,int v)

       {

        int previous[MAX-1];

        int newdist;

        bool sign[MAX];

        if(v<0||v>MAX-1)

        {

        printf("该源点不存在!\n");

        return;

        }

        for(int i=0;i<G->vexnum;i++) //初始化

        {

        dist[i]=arc[v][i];

        sign[i]=false;

        if(dist[i]==MAXNUM)

        previous[i]=0;

        else

        previous[i]=v;

        }

        dist[v]=0;

        sign[v]=true;

        for(i=0;i<G->vexnum;i++) // i<n-1 待定

        {

        float temp=MAXNUM;

        int u=v; //u 中间变量

        for(int j=0;j<G->vexnum;j++)

        if((!sign[j])&&(dist[j]<temp))

        {

        u=j;

        temp=dist[j];

        }

        sign[u]=true;

        for(j=0;j<G->vexnum;j++)

        if((!sign[j])&&(arc[u][j]<MAXNUM))

        {

        newdist=dist[u]+arc[u][j];

        if(newdist<dist[j])

        {

        dist[j]=newdist;

        previous[j]=u;

        }

        }

        }

        for(i=0;i<G->vexnum;i++)

        if(dist[i]!=MAXNUM)

        printf("从%d到%d的最短路径是 %d\n",v,i,dist[i]);

        else

        printf("从%d到%d无最短路径\n",v,i);

        printf("\n");

       }

       è¿™æ˜¯Dijkstra算法求单源最短路径算法 上程序中 假定顶点从0开始,搜索整个图,然后求出0到其他各点的最短距离,存放在dist数组中,main函数后面几行是求0到其他各点的路径 基本上能满足你的要求了

求一个道客巴巴免费账号,下载文章/p-.html

       你好,代码酷狗点歌源码该篇文章的算法算法源代码已给你上传在附件中,请直接下载吧,源码玖富钱包源码希望对你的代码湖南共享店铺源码学习研究有所帮助,还望采纳答案

        

       基于遗传算法的算法算法机器人路径规划MATLAB源码.docx

        

       算法的思路如下:取各障碍物顶点连线的中点为路径点,相互连接各路径点,源码将机器人移动的代码起点和终点限制在各路径点上,利用Dijkstra算法来求网络图的算法算法最短路径,找到从起点P1到终点Pn的源码最短路径,由于上述算法使用了连接线中点的代码条件,不是算法算法炫酷程序源码整个规划空间的最优路径,然后利用遗传算法对找到的源码最短路径各个路径点Pi (i=1,2,…n)调整,让各路径点在相应障碍物端点连线上滑动,代码原生外卖商城源码利用Pi= Pi1+ti×(Pi2-Pi1)(ti∈[0,1] i=1,2,…n)即可确定相应的Pi,即为新的路径点,连接此路径点为最优路径。

推荐资讯
回到县城体制内的她们:除了催婚,还有呢?

回到县城体制内的她们:除了催婚,还有呢?

手机外卖源码_手机外卖源码怎么弄

手机外卖源码_手机外卖源码怎么弄

游戏直播源码_游戏直播源码怎么用

游戏直播源码_游戏直播源码怎么用

php漫画源码_php动漫源码

php漫画源码_php动漫源码

快递不得擅放驿站,回到县城的女硕士,带你听见一周热点丨周末同频

快递不得擅放驿站,回到县城的女硕士,带你听见一周热点丨周末同频

变色线源码_变色线厂

变色线源码_变色线厂

copyright © 2016 powered by 皮皮网   sitemap