利用深度优先搜索求连通图G的所有关节点

上传人:飞****9 文档编号:129495953 上传时间:2020-04-23 格式:DOC 页数:3 大小:14.50KB
返回 下载 相关 举报
利用深度优先搜索求连通图G的所有关节点_第1页
第1页 / 共3页
利用深度优先搜索求连通图G的所有关节点_第2页
第2页 / 共3页
利用深度优先搜索求连通图G的所有关节点_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

《利用深度优先搜索求连通图G的所有关节点》由会员分享,可在线阅读,更多相关《利用深度优先搜索求连通图G的所有关节点(3页珍藏版)》请在金锄头文库上搜索。

1、#includeusing namespace std;#define MAX 50int LowMAX,dMAX;typedef struct ENode/定义结点 int AdjVex;/该弧所指向的的顶点位置struct ENode *NextArc;/指向下一条弧的指针int info; ArcNodeMAX;typedef structArcNode vertices;/邻接表int vexnum,arcnum;/顶点数和边数 ALGraph;ALGraph G=*(ALGraph *)malloc(sizeof(ALGraph);void DFS(int u,int p)/p为根节

2、点static int time=0;int v;Lowu=du=time+;for(ENode *w=&(G.verticesu);w;w=w-NextArc)v=w-AdjVex;if(dv=-1)/表示v未访问DFS(v,u);if(LowuLowv)Lowu=Lowv;/当孩子节点的Low值大于父亲节点的Low值,将孩子节点的Low值赋给父亲节点的Low值else if(v!=p&Lowudv)Lowu=dv;/当孩子节点不是根节点且父亲的Low值大于孩子节点的深度时,将孩子节点的深度赋给孩子节点void CreatGraph()int i,j,k,u,n=0;ENode *N;cin

3、G.vexnum;for(u=0;uG.arcnum;for(k=0;kij;/图的初始化N=(ENode *)malloc(sizeof(ENode);N-AdjVex=j;N-NextArc=G.verticesi.NextArc;G.verticesi.NextArc=N;N=(ENode *)malloc(sizeof(ENode);N-AdjVex=i;N-NextArc=G.verticesj.NextArc;G.verticesj.NextArc=N;DFS(G.vertices0.AdjVex,-1);int main()int i;int n=0;CreatGraph();for(i=0;iNextArc)if(Loww-AdjVex=di&i!=G.vertices0.AdjVex)n+;break;coutnendl;return 0;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > IT计算机/网络 > 其它相关文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号