ImageVerifierCode 换一换
格式:DOC , 页数:9 ,大小:1.59MB ,
文档编号:1863410      下载积分:6.49 文币
快捷下载
登录下载
邮箱/手机:
温馨提示:
系统将以此处填写的邮箱或者手机号生成账号和密码,方便再次下载。 如填写123,账号和密码都是123。
支付方式: 支付宝    微信支付   
验证码:   换一换

优惠套餐
 

温馨提示:若手机下载失败,请复制以下地址【https://www.163wenku.com/d-1863410.html】到电脑浏览器->登陆(账号密码均为手机号或邮箱;不要扫码登陆)->重新下载(不再收费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  
下载须知

1: 试题类文档的标题没说有答案,则无答案;主观题也可能无答案。PPT的音视频可能无法播放。 请谨慎下单,一旦售出,概不退换。
2: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
3: 本文为用户(四川天地人教育)主动上传,所有收益归该用户。163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

1,本文(Dijkstra算法原理详细讲解.doc)为本站会员(四川天地人教育)主动上传,163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。
2,用户下载本文档,所消耗的文币(积分)将全额增加到上传者的账号。
3, 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(发送邮件至3464097650@qq.com或直接QQ联系客服),我们立即给予删除!

Dijkstra算法原理详细讲解.doc

1、Dijkstra算法原理详细讲解 如下图,设 A 为源点,求 A 到其他各顶点 (B、C、D、E、F)的最短路径。 线上所标注为相邻线段之间的距离,即权值。(注:此图为随意所画,其相邻顶 点间的距离与图中的目视长度不能一一对等) 算法执行步骤如下表: Dijkstra算法的完整实现版本之算法的源代码 样例图: 输入格式: 输出格式: 输入时,将 s,t,x,y,z 五个点按照 1,2,3,4,5 起别名,输入格式按照下图例所示 当提示 Please enterthe vertexwhere Dijkstraalgorithmstarts:时输入算法的起 始点 比如计算结果 v1v4v2 表示从

2、点 1 到点 2 经过 1,4,2 为最短路径 Dijkstra 算法的完整实现版本,算法的源代码 /*Dijkstra.c Copyright (c)2002, 2006by ctu_85 AllRights Reserved. */ #includestdio.h #include malloc.h #definemaxium 32767 #definemaxver 9 /*definesthe max number of vertexswhichtheprogramm canhandle*/ #define OK 1 structPoint char vertex3; structLin

3、k *work; structPoint *next; ; structLink char vertex3; intvalue; structLink *next; ; structTable /*theworkbannch of thealgorithm*/ int cost; int Known; char vertex3; char path3; structTable *next; ; intDijkstra(structPoint *,struct Table *); intPrintTable(int,struct Table *); int PrintPath(int,struc

4、tTable *,struct Table *); structTable *CreateTable(int,int); structPoint * FindSmallest(structTable *,struct Point *);/*Find the vertexwhich has the smallestvalue resideinthe table*/ intmain() inti,j,num,temp,val; char c; structPoint *poinpre,*poinhead,*poin; structLink *linpre,*linhead,*lin; struct

5、Table *tabhead; poinpre=poinhead=poin=(structPoint *)malloc(sizeof(structPoint); poin-next=NULL; poin-work=NULL; restart: printf(Notice:ifyouwanna toinput avertex,you must use the format of number!n); printf(Please input thenumber of points:n); scanf(%d, if(nummaxver|num1|num%1!=0) printf(nNumber of

6、 points exception!); goto restart; for(i=0;inext=poin; poin-vertex0=v; poin-vertex1=0+i+1; poin-vertex2=0; linpre=lin=poin-work; linpre-next=NULL; for(j=0;jnext=NULL; break; else lin=(structLink *)malloc(sizeof(structLink); linpre-next=lin; lin-vertex0=v; lin-vertex1=0+temp; lin-vertex2=0; printf(Pl

7、ease input the valuebetwixt %dth point towards %dth point:,i+1,temp); scanf(%d, lin-value=val; linpre=linpre-next; lin-next=NULL; poinpre=poinpre-next; poin-next=NULL; printf(Pleaseenter thevertexwhereDijkstra algorithmstarts:n); scanf(%d, tabhead=CreateTable(temp,num); Dijkstra(poinhead,tabhead); P

8、rintTable(temp,tabhead); returnOK; structTable * CreateTable(intvertex,int total) structTable *head,*pre,*p; int i; head=pre=p=(structTable *)malloc(sizeof(structTable); p-next=NULL; for(i=0;inext=p; if(i+1=vertex) p-vertex0=v; p-vertex1=0+i+1; p-vertex2=0; p-cost=0; p-Known=0; else p-vertex0=v; p-v

9、ertex1=0+i+1; p-vertex2=0; p-cost=maxium; p-Known=0; p-next=NULL; pre=pre-next; returnhead; intDijkstra(structPoint *p1,struct Table *p2) /*Core of the programm*/ intcosts; char temp; structPoint *poinhead=p1,*now; structLink *linna; structTable *tabhead=p2,*searc,*result; while(1) now=FindSmallest(

10、tabhead,poinhead); if(now=NULL) break; result=p2; result=result-next; while(result!=NULL) if(result-vertex1=now-vertex1) break; else result=result-next; linna=now-work-next;while(linna!=NULL) /*update allthe vertexslinkedto thesigned vertex*/ temp=linna-vertex1; searc=tabhead-next; while(searc!=NULL

11、) if(searc-vertex1=temp)/*findthe vertexlinked tothe signedvertexinthe tableand update*/ if(result-cost+linna-value)cost) searc-cost=result-cost+linna-value;/*setthe new value*/ searc-path0=v; searc-path1=now-vertex1; searc-path2=0; break; else searc=searc-next; linna=linna-next; return1; structPoin

12、t * FindSmallest(structTable *head,struct Point *poinhead) structPoint *result; structTable *temp; intmin=maxium,status=0; head=head-next; poinhead=poinhead-next; while(head!=NULL) if(!head-Known result=poinhead; temp=head; status=1; head=head-next; poinhead=poinhead-next; if(status) temp-Known=1; r

13、eturnresult; else returnNULL; int PrintTable(int start,struct Table *head) structTable *begin=head; head=head-next; while(head!=NULL) if(head-vertex1-0)!=start) PrintPath(start,head,begin); head=head-next; returnOK; int PrintPath(int start,struct Table *head,structTable *begin) structTable *temp=begin-next,*p,*t; p=head; t=begin; if(p-vertex1-0)!=start PrintPath(start,temp,t); printf(%s,p-vertex); else if(p!=NULL) printf(n%s,p-vertex); returnOK;

侵权处理QQ:3464097650--上传资料QQ:3464097650

【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。


163文库-Www.163Wenku.Com |网站地图|