ImageVerifierCode 换一换
格式:DOCX , 页数:9 ,大小:16.19KB ,
资源ID:6088676      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6088676.html】到电脑端继续下载(重复下载不扣费)。

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

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(最新邻接表prim算法教学教材.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

最新邻接表prim算法教学教材.docx

1、最新邻接表prim算法教学教材#include#include#define MAX_VERTEX_NUM 20#define MAX 32767#define ERROR 0#define OK 1#define OVERFLOW -2typedef int Status;typedef char VertexType;typedef int PathMatrix MAX_VERTEX_NUM MAX_VERTEX_NUM;typedef int ShortPathTable MAX_VERTEX_NUM;bool visitedMAX_VERTEX_NUM;bool finalMAX_VE

2、RTEX_NUM;typedef struct char adj; int lowcost; closedgeMAX_VERTEX_NUM;typedef struct ArcNodeint adjvex;/弧所指向的顶点的位置struct ArcNode *nextarc;/指向下一条弧的指针int weight;/权重/InfoType *info;/该弧相关信息的指针ArcNode;typedef struct VNodeVertexType data;/顶点信息ArcNode *firstarc;VNode,AdjListMAX_VERTEX_NUM;typedef struct Ad

3、jList vertices;int vexnum,arcnum;int kind;ALGraph;/-/队列typedef struct nodeint data;struct node *next;QNode,*QueuePtr;typedef struct QueuePtr front; QueuePtr rear;LinkQueue;/构造一个空队列Status InitQueue(LinkQueue &Q)Q.front=Q.rear=(QueuePtr)malloc(sizeof(QNode); if(!Q.front) exit(OVERFLOW); Q.front-next=N

4、ULL; return OK;/插入元素Status EnQueue(LinkQueue &Q,int &e)QueuePtr p; p=(QueuePtr)malloc(sizeof(QNode); if(!p) exit(OVERFLOW); p-data=e; p-next=NULL; Q.rear-next=p; Q.rear=p; return OK;/出队列Status DeQueue(LinkQueue &Q,int &e)QueuePtr p; if(Q.front=Q.rear)return ERROR; p=Q.front-next; e=p-data; Q.front-n

5、ext =p-next; if(p=Q.rear)Q.rear=Q.front; free(p); return OK;Status QueueEmpty(LinkQueue &Q)if(Q.front=Q.rear) return OK; else return ERROR;/*-*/int LocateVex(ALGraph G,char e) int i; for(i=0;iG.vexnum;i+) if(e=G.verticesi.data) return i; return -1;/创建图int CreateGraph(ALGraph &G)int i,j,w,k;char V1,V

6、2;printf(输入顶点数,弧数:);scanf(%d%d,&G.vexnum,&G.arcnum);for(i=0;iG.vexnum;i+) printf(输入第%d个顶点的值:,i+1); scanf(n%c,&G.verticesi.data); fflush(stdin);G.verticesi.firstarc=NULL;ArcNode* p;for(i=0;iadjvex=k; p-weight=w; p-nextarc=G.verticesj.firstarc; G.verticesj.firstarc=p;return OK;/邻接表表示的深度优先搜索算法 void DFS

7、(ALGraph G,int v)int j;ArcNode* q;visitedv=OK;printf(%c ,G.verticesv.data ); q=G.verticesv.firstarc; for(;q;q=q-nextarc) j=q-adjvex; if(!visitedj) DFS(G,j); /邻接表表示的广度优先搜索算法 void BFS(ALGraph G,int v)int i,u;ArcNode* q;for(i=0;iMAX_VERTEX_NUM;i+) visitedi=ERROR; LinkQueue Q;InitQueue(Q);for(i=v;inexta

8、rc) if(!visitedu) EnQueue(Q,u); int minium(closedge a,ALGraph G)int i=0,j,k,min; while(!ai.lowcost) i+; min=ai.lowcost; / 第一个不为0的值 k=i; for(j=i+1;j0) if(minaj.lowcost) min=aj.lowcost; k=j; return k;void MiniSpanTree_PRIM(ALGraph &G,char u) int k,j,i; ArcNode* q; closedge a; for(j=0;jadjvex.adj=G.ver

9、ticesk.data; aq-adjvex.lowcost=q-weight ; q=q-nextarc; ak.lowcost=0; printf(n最小代价生成树的各条边为:n); for(i=1;iweightadjvex.lowcost) aq-adjvex.adj=G.verticesk.data; aq-adjvex.lowcost=q-weight ; q=q-nextarc; /void ShortestPath_DIJ(ALGraph &G1,int v0,PathMatrix &p,ShortPathTable &D)int v,i,min,w,j; ArcNode* q

10、; q=G1.verticesv0.firstarc; for(v=0;vG1.vexnum;v+) finalv=false; Dv=MAX; for(w=0;wadjvex=q-weight; pq-adjvexv0=true; pq-adjvexq-adjvex=true; q=q-nextarc; Dv0=0; finalv0=true; for(i=1;iG1.vexnum;i+) min=MAX; for(w=0;wG1.vexnum;w+) if(!finalw) if(Dwadjvex&min+q-weightadjvex) Dq-adjvex=min+q-weight; fo

11、r(j=0;jadjvexj=pvj; pq-adjvexq-adjvex=true; q=q-nextarc; void main() int i,start,start1,j;char c;PathMatrix p; ShortPathTable d;for(i=0;iMAX_VERTEX_NUM;i+)visitedi=ERROR;ALGraph G;CreateGraph(G);printf(深度优先遍历开始位置:);scanf(%d,&start);DFS(G,start);printf(n广度优先遍历开始元素:); scanf(%d,&start1);BFS( G,start1); printf(nprim算法开始元素:);scanf(n%c,&c);MiniSpanTree_PRIM(G, c );ShortestPath_DIJ(G,0,p,d);for(i=0;iG.vexnum;+i) for(j=0;jG.vexnum;+j) printf(%2d,pij); printf(n); printf(%c到各顶点的最短路径长度为:n,G.vertices0.data); for(i=1;iG.vexnum;+i) printf(%c-%c:%dn,G.vertices0.data,G.verticesi.data,di);

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1