



免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
利用邻接表存储无向图,并深度遍历和广度遍历图#include #include #include #define max 20int visitedmax;int w;typedef struct arcnodeint adjvex;/该弧指向的顶点的位置struct arcnode *nextarc;/弧尾相同的下一条弧char *info;/该弧信息arcnode;typedef struct vnodechar data;/结点信息arcnode *firstarc;/指想第一条依附该结点的弧的指针vnode,adjlist;typedef structadjlist verticesmax;int vexnum,arcnum;int kind;algraph;typedef struct qnodeint data;struct qnode *next;qnode,*queueptr;typedef structqueueptr front;queueptr rear;linkqueue;void dfs(algraph gra,int i);int creatadj(algraph &gra)/用邻接表存储图int i,n,m;char cha;coutn;coutm;arcnode *arc,*tem;for(i=0;in;i+)coutgra.verticesi.data;gra.verticesi.firstarc=NULL;for(i=0;in;i+)cout结点icha;if(cha=y)arc=(arcnode *)malloc(sizeof(arcnode);cinarc-adjvex;gra.verticesi.firstarc=arc;coutcha;while(cha=y)tem=(arcnode *)malloc(sizeof(arcnode);cintem-adjvex;arc-nextarc=tem;arc=tem;coutcha;arc-nextarc=NULL;if(cha=n)continue;gra.vexnum=n;gra.arcnum=m;return 1;int firstadjvex(algraph gra,vnode v)/返回依附顶点V的第一个点/即以V为尾的第一个结点return v.firstarc-adjvex;int nextadjvex(algraph gra,vnode v,int w)/返回依附顶点V的相对于W的下一个顶点arcnode *p;p=v.firstarc;while(p!=NULL)if(p-adjvex!=w)p=p-nextarc;if(p-adjvex=w&p-nextarc!=NULL)return p-nextarc-adjvex;else return 0;int initqueue(linkqueue &q)/初始化队列q.rear=(queueptr)malloc(sizeof(qnode);q.front=q.rear;if(!q.front)return 0;q.front-next=NULL;return 1;int enqueue(linkqueue &q,int e)/入队queueptr p;p=(queueptr)malloc(sizeof(qnode);if(!p)return 0;p-data=e;p-next=NULL;q.rear-next=p;q.rear=p;return 1;int dequeue(linkqueue &q,int &e)/出队queueptr p;if(q.front=q.rear)return 0;p=q.front-next;e=p-data;q.front-next=p-next;if(q.rear=p)q.rear=q.front;free(p);return 1;int queueempty(linkqueue q)/判断队为空if(q.front=q.rear)return 1;return 0;void bfstra(algraph gra,vnode v)/广度优先遍历int i,e;linkqueue q;for(i=0;igra.vexnum;i+)visitedi=0;initqueue(q);for(i=0;igra.vexnum;i+)if(!visitedi)visitedi=1;cout0;w=nextadjvex(gra,gra.verticese,w)if(!visitedw)visitedw=1;coutgra.verticesw.data;enqueue(q,w);int dfstra(algraph gra,vnode v)/深度优先遍历int i;for(i=0;igra.vexnum;i+)visitedi=0;for(i=0;igra.vexnum;i+)if(!visitedi)dfs(gra,i);return 1;void dfs(algraph gra,int i)visitedi=1;cout0;w=nextadjvex(gra,gra.verticesi,w)if(!visitedw)dfs(gra,w);
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年药理学跨学科应用案例分析答案及解析
- 2025年急诊科五大致命病症识别考核试卷答案及解析
- 2025年呼吸系统疾病诊疗技术综合测试卷答案及解析
- 高考英语模拟试题(浙江温州版)及解析
- 青少年入门英语测试卷设计
- 兽医专业诊断宠物疾病
- 人力资源招聘政策
- 2025内蒙古民族幼儿师范高等专科学校单招《职业适应性测试》试卷加答案详解
- 2025年放射科影像诊断解读竞赛答案及解析
- 养生保健产业的政策法规与促进措施
- 2025文具用品采购合同范本格式
- 树木学试题及答案北林
- 电气检修生产安全培训课件
- 2025第三季度作风建设党课以忠诚廉洁担当的政治品格奋力书写高质量发展新答卷
- 《2025新版检验检测机构管理评审报告》
- 2025劳动教育考试试题及答案
- 江苏省南通市如皋市2025-2026学年高三上学期开学考试数学试卷
- 宠物急救标准化流程
- 焊工考试理论考试题库及答案
- 云原生压测技术-洞察及研究
- 送货服务方案
评论
0/150
提交评论