已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026江苏盐城市卫生健康委部分直属事业单位招聘专业技术人员备考题库及答案详解(易错题)
- 2026华东师范大学附属闵行永德学校(永德路校区)编外水电工招聘1人备考题库有完整答案详解
- 2026江苏南通开放大学招聘高层次人才5人备考题库含答案详解(考试直接用)
- 2026南昌市社会福利院招聘2人备考题库及完整答案详解一套
- 2026河南省医学科学院王宁利院士团队招聘工作人员备考题库附答案详解(巩固)
- 2026华泰证券跨境管培GTP国际校园招聘备考题库含答案详解(巩固)
- 2026四川创锦发展控股集团有限公司招聘2人备考题库附答案详解(b卷)
- 2026山东艺术学院招聘9人备考题库附答案详解(突破训练)
- 2026年舟山市普陀区桃花镇镇、村工作人员招聘3人笔试备考试题及答案解析
- 2026年宁德市蕉城区教育局公开补充招聘紧缺急需人才4人笔试参考题库及答案解析
- 《液压元件符号》课件
- 《景泰蓝的制作》叶圣陶-中职高一语文(高教版2023基础模块下册)
- 鄂托克前旗新寨子砖厂浓盐水处理项目环评报告书
- 国开计算机组网技术实训1:组建小型局域网
- 医院海姆立克急救操作考核评分标准
- 动力换档变速器设计课件
- (全)附着式升降脚手架监理实施细则
- 考生报名承诺书
- 逻辑学导论(中山大学)【超星尔雅学习通】章节答案
- DB51T 2880-2022建设放心舒心消费城市通用要求
- 新能源之氢能
评论
0/150
提交评论