校园导游图的课程设计(二)

周二:

主要完成了 两个任务

    一:全部简单路径的查找

    二 : 最短路径的查找

一:简单路径:顶点序列中顶点不重复出现的路径。

     方法是 递归 和 简单回溯,但是没看懂,为了赶进度,只能先用这了,附上链接,用的是c++ 和矩阵存储

    我将代码改了,用的是 c 和 邻接表

void ShortestEasyPath( ListMatrix * G, int star, int end, int path[],int d,int  allpath[][NUMMAX],int* count )
{//d初始化为0,标记路的长度      allpath 用来存放走过的路径    count 用来标记存在那一行
        int m,i;
        ArcNode *p;

        visited[star] = 1; // 标记已访问
        d++;//长度加一
        path[d] = star;//路径符号进入
        if( star == end )
        {
                (*count)++;
                allpath[*count][0] = d;
                for( i=1; i<=d; i++ )
                       allpath[*count][i] = path[i];
        }//开始等与结束时,输出路径
        p =G->vertex[star].next;

        while( p!=NULL )
        {
                m = p->adjvex;
                if(!visited[m])
                    ShortestEasyPath(G,m,end,path,d,allpath,count);
                p = p->next;
        }
        visited[star]=0;//访问回溯遍历,这是代码核心,但看不懂
}

二:最短路径,使用的是dijkstra的方法,不用floyd是因为路径不好存储,唯一的特色是建立在 邻接表, 而不是一般人用的邻接邻接矩阵

void ShortestPath( ListMatrix *G,int start, int dist[], int path[][NUMMAX])
{//path 用来存储路径 
        int mindist;
        int i,j,k;
        int t = 1;
        ArcNode * p;


        for( i=1; i<=G->vexnum; i++ )
        {
                dist[i] = INFNITY; 
        }
        p = G->vertex[start].next;
        while( p!=NULL )
        {
                dist[p->adjvex] = p->weight;
                path[p->adjvex][1] = start;//任一个和start相连的点,第一个必为 start
                p = p->next;
        }

        path[start][0] = 1;//进入v集

        for( i=2; i<=G->vexnum; i++ )
        {
                mindist = INFNITY;//初始化

                for( j=1; j<=G->vexnum; j++ )
                {
                        if(!path[j][0]&&dist[j]<mindist)
                        {
                                k = j;
                                mindist = dist[j];
                        }
                }//寻找最短的哪一个k
                
                if( mindist == INFNITY ) return;
                 
                path[k][0] = 1;//入V集

                p = G->vertex[k].next;//查看他连通几个点
                while( p!=NULL )
                {
                        if( mindist+p->weight < dist[p->adjvex] )//是否满足变短
                        {
                                dist[p->adjvex] = mindist+p->weight;//改变dist的值

                                t = 1;
                                while( path[k][t] != 0 )
                                {
                                        path[p->adjvex][t] = path[k][t];
                                        t++;
                                }

                                path[p->adjvex][t] = k;
                                path[p->adjvex][t+1] = 0;//将到从start点到p->adjvex 点的路径放入 对应的path[p->adjvex][]
                        }

                        p = p->next;
                }//while 判断与k 相连的节点,是否可以通过k,缩短路径长度

        }//for 循环 n-1 次找到n-1的最短路径
}

 

转载于:https://www.cnblogs.com/dilidingzhi/p/4154386.html

Main()函数模:主要打印开始界面和提示相关的操作。用穷举的方法把学校相关景点之间的路径和权值(距离)初始化,用cost[][]维数组实现。打印:输入”s”进行查询最短路径,输入“b”进入主菜单页面,输入“e”退出程序。 switch(k) { case'b':star();break; case 's': printf("the shortest way searching:"); shortestdistance(); break; case 'e': exit(0); default:printf("Error!\nplease press b or s or e.\n");getchar();break; } Star()函数:主要是显示一个界面,功能是提供查询路径选择和查看进入景点的主页面和退出该页面返回主界面。 switch(choose) {case '0':instruction();getchar();break; case '1':jingdian();break; case '2': map();break; case '9':end();break; default:star(); } Jingdian()函数:显示校园的10个景点和代号,提示输入相应的代号进入该景点的函数模块。在这里也可以查询10个景点中任意两个之间的最短路径,也可以选择退出程序。 switch(point) { case '1': office();break; case '2': library();break; case '3': lake();break; case '4': classroom();break; case '5': apartment();break; case 's':shortestdistance();break; case '0': star();getchar();break; case 'e':exit(0); default:jingdian(); } Floyed()函数:求两个景点之间的最短距离。 for(i=1;i<=n;i++) for(j=1;j<=n;j++) { shortest[j]=cost[j]; path[j]=0; } for(k=1;k<=n;k++) for(i=1;i<=n;i++) for(j=1;j(shortest[k]+shortest[k][j])) {/*用path[][]记录从i到j的最短路径上点j的前驱景点的序号*/ shortest[j]=shortest[k]+shortest[k][j]; path[j]=k; path[j]=k; display(int i,int j)函数:打印两个景点之间的最短路径。 if(shortest[j]!=INT_MAX) { if(i<j) { printf("%d",b); while(path[j]!=0) {/*把i到j的路径上所有经过的景点按逆序打印出来*/ printf("<-%d",path[j]); if(i<j) j=path[j]; else i=path[j]; } printf("%d)the distance is:%dm\n\n",a,b,shortest[a]); } else { printf("%d",a); while(path[j]!=0) {/*把i到j的路径上所有经过的景点按顺序打印出来*/ printf("->%d",path[j]); if(i%d",b); printf("\n\n"); printf("(%d->%d)the shortest distance is:]m\n\n",a,b,shortest[a]); } 其余几个函数是学校景点的相应介绍。调用后都可以回到jingdian()函数的主界面。 End()函数是一个结束函数,打印结束语,执行退出命令。 void end() { char r; clrscr(); printf("THANK YOU AND YOUR WELCOME AGAIN\n"); printf("PLEASE INPUT ANY KEY EXIT !\n"); getchar(); scanf("%c",&r); exit(0); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值