- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[2018年最新整理]图的遍历源代码(C语言)
图的遍历顺序有两种:深度优先搜索(DFS)和广度优先搜索(BFS)。深度优先遍历的基本思想是:首先从图中某个顶点v0出发,访问此顶点,然后依次从v0相邻的顶点出发深度优先遍历,直至图中所有与v0路径相通的顶点都被访问了;若此时尚有顶点未被访问,则从中选一个顶点作为起始点,重复该步骤直到所有的顶点都被访问。而广度优先遍历首先从图的某个顶点v0出发,访问了v0之后,依次访问与v0相邻的未被访问的顶点,然后分别从这些顶点出发,广度优先遍历,直至所有的顶点都被访问完。流程图如下:程序代码如下:#includeiostream#includeprocess.h#includestdlib.h#define MaxVerNum 50 using namespace std;struct edgenode{int endver;int inform;edgenode* edgenext; };struct vexnode {char vertex;edgenode* edgelink;};struct Graph {vexnode adjlists[MaxVerNum];int vexnum;int arcnum;};//队列的定义及相关函数的实现struct QueueNode{int nData;QueueNode* next;};struct QueueList {QueueNode* front;QueueNode* rear;};void EnQueue(QueueList* Q,int e){QueueNode *q=new QueueNode;q-nData=e;q-next=NULL;if(Q==NULL)return;if(Q-rear==NULL)Q-front=Q-rear=q;else{Q-rear-next=q;Q-rear=Q-rear-next;}}void DeQueue(QueueList* Q,int* e){if (Q==NULL)return;if (Q-front==Q-rear){*e=Q-front-nData;Q-front=Q-rear=NULL;}else{*e=Q-front-nData;Q-front=Q-front-next;}}//创建图void CreatAdjList(Graph* G){int i,j,k;edgenode* p1;edgenode* p2;cout请输入顶点数和边数:endl;cinG-vexnumG-arcnum;cout开始输入顶点表:endl;for (i=0;iG-vexnum;i++){cinG-adjlists[i].vertex;G-adjlists[i].edgelink=NULL;}cout开始输入边表信息:endl;for (k=0;kG-arcnum;k++){cout请输入各边对应的顶点Vi,Vj:;cinij;p1=new edgenode;p1-endver=j;p1-edgenext=G-adjlists[i].edgelink;G-adjlists[i].edgelink=p1;p2=new edgenode;p2-endver=i;p2-edgenext=G-adjlists[j].edgelink;G-adjlists[j].edgelink=p2;//因为是无向图,所以有两次建立边表的过程}}//-------------------------------------------------------------深度优先遍历void DFS(Graph *G,int i,int visit[]){coutG-adjlists[i].vertex ;visit[i]=1;edgenode *p=new edgenode;p=G-adjlists[i].edgelink;if(G-adjlists[i].edgelink!visit[p-endver]){DFS(G,p-endver,visit);}}void DFStraversal(Graph *G,char c)//深度优先遍历{cout该图的深度优先遍历结果为:endl;int visit[MaxVerNum];for(int i=0;iG-vexnum;i++){visit[i]=0;//全部初始化为0,即未访问状态}int m;for (i=0;iG-vexnum;i++){if (G-adjlists[i].vertex==c)//根据字符查找序号{m=i;DFS(G,i,visit);break;}}//继续访问未被访问的结点for(i=0;iG-vexnum;i++){if(visit[i]==0)DFS(G,i,visit);}coutendl
您可能关注的文档
- [2018年最新整理]国家公共卫生信息系统建设方案.doc
- [2018年最新整理]国家公共卫生服务知识知识讲座.doc
- [2018年最新整理]国学常识题库.ppt
- [2018年最新整理]国家公务员面试专项精讲系列之综合分析能力.docx
- [2018年最新整理]国外奢侈家具品牌.doc
- [2018年最新整理]国外高端奢华家具饰品挂画布艺顶级配饰 软装设计方案素材【名师联.596期】.doc
- [2018年最新整理]国家基本公共卫生服务孕产妇保健和儿童保健.ppt
- [2018年最新整理]国家基本公共卫生服务规范(2011年版)高血压糖尿病部分及填表说明.doc
- [2018年最新整理]国家基本公共卫生服务规范-2型糖尿病患者健康管理.ppt
- [2018年最新整理]国家基本公共卫生服务规范0-6岁.ppt
文档评论(0)