




已阅读5页,还剩5页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
邻接矩阵表示的图的基本操作的实现/采用邻接矩阵完成无权无向及有向图的建立、输出、深度遍历、广度遍历操作#include #include #define OK 1#define ERROR -1typedef int Status;typedef int ElemType; /此例中设元素为单值元素,类型为整型#define MAX_VERTEX_NUM 20 /最大顶点个数typedef int ElemType; /图顶点数据类型typedef int QueueElemType;/队列结点数据类型/链表结点类型定义typedef struct QnodeQueueElemType data;struct Qnode *next;QNode;/队列类型定义:typedef struct LinkqueueQNode *front,*rear;LinkQueue;/图的数据类型定义typedef struct MgraphElemType vectorMAX_VERTEX_NUM; /顶点向量int adjMAX_VERTEX_NUMMAX_VERTEX_NUM;/邻接矩阵int vexnum; /图中当前顶点数int arcnum; /图中当前边数 MGraph;/队列初始化Status InitLinkQueue(LinkQueue *Q)QNode *p;p=(QNode*)malloc(sizeof(QNode);/开辟头结点空间if(p!=NULL)p-next=NULL;Q-front=Q-rear=p;return OK;elsereturn ERROR;/链式队列的入队操作,在已知队列的队尾插入一个元素e,修改队尾指针rear。Status InsertLinkQueue(LinkQueue *Q,ElemType e)QNode *p;p=(QNode*)malloc(sizeof(QNode);if(p=NULL)return ERROR;/申请新结点空间失败,返回错误标志elsep-data=e;/存入新结点数据p-next=NULL;Q-rear-next=p;/新结点插入到队尾Q-rear=p;/新插入结点成为新的队尾return OK;/链式队列的出队操作,取第一个数据结点的数据后删除该结点Status DeleteLinkQueue(LinkQueue *Q,ElemType *e)QNode *p;if(Q-front=Q-rear)/可改为:if(Q-front-next=NULL)return ERROR;/队空elsep=Q-front-next;/取队首结点*e=p-data;Q-front-next=p-next;/修改队首指针if(p=Q-rear)/条件成立说明只有一个数据结点Q-rear=Q-front;/当队列只有一个数据结点时应防止丢失队尾指针free(p);Q-rear-next=NULL;return OK;/判断队列是否为空Status IsEmptyLinkQueue(LinkQueue *Q)if(Q-front=Q-rear)return OK;elsereturn ERROR;/释放队列void DestroyLinkQueue(LinkQueue *Q)QNode *p,*q;p=Q-front;/指向链表第一个结点,即整个链表的第一个结点while(p!=NULL)q=p-next;/保存链表后半段首地址以防丢失free(p);p=q;/*以下为图的操作*/顶点在顶点向量中的定位,找到返回OK,否则返回ERROR/G为的数据结构,v为待查顶点,n用于返回找到的顶点下标Status LocateVex(MGraph G,ElemType v,int *n)int i;for(i=0;(iG.vexnum)&(G.vectori!=v);i+);*n=i;if(ivexnum),&(G-arcnum);fflush(stdin);printf(请输入%d个顶点信息:n,G-vexnum);for(i=0;ivexnum;i+) /输入顶点向量scanf(%d,&(G-vectori);printf(顶点向量如下:n); /输出顶点向量for(i=0;ivexnum;i+)printf(%4d,G-vectori);printf(n无向图还是有向图,0-无向图 其它-有向图:);scanf(%d,&sfyxt);for(i=0;ivexnum;i+) /邻接矩阵初始化for(j=0;jvexnum;j+)G-adjij=0;printf(n请输入无权图的边(共%d条)n,G-arcnum);printf(格式为:vi vj,vi及vj表示结点内容,注意有向图结点输入的前后次序:n);for(k=0;karcnum;k+) /输入无权图的边 fflush(stdin);printf(No.%2d/%d:,k+1,G-arcnum);scanf(%d%d,&v1,&v2);LocateVex(*G,v1,&i);LocateVex(*G,v2,&j);G-adjij=1;if(sfyxt=0)/无向图则同时产生两条边的信息G-adjji=G-adjij; /输出无向图的邻接矩阵void PrintGraph(MGraph G)int i,j;printf(图信息如下:n);printf(%4s, );for(i=0;iG.vexnum;i+)printf(%4d,G.vectori);printf(n);for(i=0;iG.vexnum;i+)printf(%4d,G.vectori);for(j=0;jG.vexnum;j+)printf(%4d,G.adjij);printf(n); /查找顶点v的第一个邻接点,v为当前顶点下标int FirstAdjVex(MGraph G,int v)int j,p=-1,found=1;for(j=0;(jG.vexnum)&(found=1);j+)if(G.adjvj=1)p=j;found=0;return p;/查找顶点v的下一个邻接点,w为当前邻接点下标int NextAdjVex(MGraph G,int v,int w)int j,p=-1,found=1;for(j=w+1;(j=0;w=NextAdjVex(G,v,w) if(visitedw=0)Dfs(G,w);void DfsTraverse(MGraph G)int v;for(v=0;vG.vexnum;v+)visitedv=0;for(v=0;vG.vexnum;v+)if(visitedv=0)Dfs(G,v);/广度优先遍历void BfsTraverse(MGraph G)int v,u,w;LinkQueue Q;for(v=0;vG.vexnum;v+)visitedv=0;InitLinkQueue(&Q);for(v=0;v=0;w=NextAdjVex(G,u,w)if(visitedw=0)visitedw=1;printf(%4d,G.vectorw);InsertLinkQueue(&Q,w);DestroyLinkQueue(&Q);/主函数void main()int xz=1;MGraph G;while(xz!=0)printf(1输入图信息n);printf(2输出图信息n);printf(3图的深度优先遍历n);printf(4图的广度优先遍历n);printf(0退出n请选择:);fflush(stdin);scanf(%d,&xz);switch(xz)case 1:CreateGraph
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年山东苯甲酸项目申请报告模板范文
- 初中生物知识激发方法(含学习方法技巧、例题示范教学方法)
- 某港口码头项目预可行研究报告
- 黄巾起义漫画课件
- 2025年中国石碱项目商业计划书
- 2025年新能源汽车电池管理系统智能化升级对电动汽车行业标准的影响报告
- 2025年中国麝香项目商业计划书
- 2025年中国莽草酸项目创业计划书
- 2025年低空经济航空俱乐部会员权益与忠诚度分析报告
- 2025年铁路货物运输服务项目可行性研究报告
- 穴位贴敷操作技术
- 2025年四川省基层法律服务工作者执业核准考试历年参考题库含答案详解(5套)
- 露天煤矿应急救援
- 2025中国高血压防治指南
- 特色产业园汇报
- 2025年上半年实验室管理体系内审资料
- 光伏安全文明施工专项方案
- 模具制造工艺(第三版) 课件 项目三锻模零件机械加工工艺
- 燃气锅炉安全培训
- 全科教学病例讨论指南
- GCP质量控制培训课件
评论
0/150
提交评论