深度优先遍历,这个跟树中的遍历类似,做深度遍历就是访问一个节点之后,在访问这个节点的子节点,依次下去是一个递归的过程。

具体代码:

void DFS(MGraph g ,int i)
{
    int j;
    visited[i]=1;
    printf("%c",g.vexs[i]);
    for(j = 0;j<g.numVertexes;j++)
    {
        if(g.arc[i][j]==1&&visited[i]!=1)
        {
            DFS(g,j);
        }
    }
}

完整代码如下,这边对图的存储结构采用了邻接矩阵

  1: #include <stdio.h>
  2:
  3: #define MAXVEX 9
  4: #define INFINITY 65535
  5:
  6: typedef struct MGraph
  7: {
  8: 	char vexs[MAXVEX];
  9: 	int arc[MAXVEX][MAXVEX];
 10:     int numVertexes, numEdges;
 11: }MGraph;
 12:
 13: int visited[MAXVEX];
 14:
 15: void createMGraph(MGraph *g);
 16: void DFS(MGraph g ,int i);
 17: void DFSTraverse(MGraph g);
 18:
 19: void createMGraph(MGraph *g)
 20: {
 21: 	int i, j;
 22:
 23: 	g->numEdges=15;
 24: 	g->numVertexes=9;
 25:
 26: 	g->vexs[0]='A';
 27: 	g->vexs[1]='B';
 28: 	g->vexs[2]='C';
 29: 	g->vexs[3]='D';
 30: 	g->vexs[4]='E';
 31: 	g->vexs[5]='F';
 32: 	g->vexs[6]='G';
 33: 	g->vexs[7]='H';
 34: 	g->vexs[8]='I';
 35:
 36:
 37: 	for (i = 0; i < g->numVertexes; i++)
 38: 	{
 39: 		for ( j = 0; j < g->numVertexes; j++)
 40: 		{
 41: 			g->arc[i][j]=0;
 42: 		}
 43: 	}
 44:
 45: 	g->arc[0][1]=1;
 46: 	g->arc[0][5]=1;
 47:
 48: 	g->arc[1][2]=1;
 49: 	g->arc[1][8]=1;
 50: 	g->arc[1][6]=1;
 51:
 52: 	g->arc[2][3]=1;
 53: 	g->arc[2][8]=1;
 54:
 55: 	g->arc[3][4]=1;
 56: 	g->arc[3][7]=1;
 57: 	g->arc[3][6]=1;
 58: 	g->arc[3][8]=1;
 59:
 60: 	g->arc[4][5]=1;
 61: 	g->arc[4][7]=1;
 62:
 63: 	g->arc[5][6]=1;
 64:
 65: 	g->arc[6][7]=1;
 66:
 67:
 68: 	for(i = 0; i < g->numVertexes; i++)
 69: 	{
 70: 		for(j = i; j < g->numVertexes; j++)
 71: 		{
 72: 			g->arc[j][i] =g->arc[i][j];
 73: 		}
 74: 	}
 75:
 76: }
 77:
 78:
 79: void DFS(MGraph g ,int i)
 80: {
 81:     int j;
 82:     visited[i]=1;
 83:     printf("%c",g.vexs[i]);
 84:     for(j = 0;j<g.numVertexes;j++)
 85:     {
 86:         if(g.arc[i][j]==1&&visited[i]!=1)
 87:         {
 88:             DFS(g,j);
 89:         }
 90:     }
 91: }
 92:
 93: void DFSTraverse(MGraph g)
 94: {
 95:     int i;
 96:     for(i=0;i<g.numVertexes;i++)
 97:     {
 98:         visited[i] = 0;
 99:     }
100:     for(i = 0;i<g.numVertexes;i++)
101:     {
102:         if(visited[i]!=1)
103:         {
104:             DFS(g,i);
105:         }
106:     }
107: }
108:
109: int main()
110: {
111:     MGraph g;
112:     createMGraph(&g);
113:     DFSTraverse(g);
114:     return 0;
115: }
116: 

深度优先遍历DFS的更多相关文章

  1. 图的深度优先遍历(DFS)和广度优先遍历(BFS)

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  2. 广度优先遍历-BFS、深度优先遍历-DFS

    广度优先遍历-BFS 广度优先遍历类似与二叉树的层序遍历算法,它的基本思想是:首先访问起始顶点v,接着由v出发,依次访问v的各个未访问的顶点w1 w2 w3....wn,然后再依次访问w1 w2 w3 ...

  3. 图的深度优先遍历DFS

    图的深度优先遍历是树的前序遍历的应用,其实就是一个递归的过程,我们人为的规定一种条件,或者说一种继续遍历下去的判断条件,只要满足我们定义的这种条件,我们就遍历下去,当然,走过的节点必须记录下来,当条件 ...

  4. 图的深度优先遍历(DFS)—递归算法

    实验环境:win10, DEV C++5.11 实验要求: 实现图的深度优先遍历 实验代码: #include <iostream> #define maxSize 255 #includ ...

  5. 图的深度优先遍历(DFS) c++ 非递归实现

    深搜算法对于程序员来讲是必会的基础,不仅要会,更要熟练.ACM竞赛中,深搜也牢牢占据着很重要的一部分.本文用显式栈(非递归)实现了图的深度优先遍历,希望大家可以相互学习. 栈实现的基本思路是将一个节点 ...

  6. 16.boost图深度优先遍历DFS

    #include <iostream> #include <boost/config.hpp> //图(矩阵实现) #include <boost/graph/adjac ...

  7. 图的深度优先遍历(DFS)和广度优先遍历(BFS)算法分析

    1. 深度优先遍历 深度优先遍历(Depth First Search)的主要思想是: 1.首先以一个未被访问过的顶点作为起始顶点,沿当前顶点的边走到未访问过的顶点: 2.当没有未访问过的顶点时,则回 ...

  8. C++版 - 剑指Offer 面试题39:二叉树的深度(高度)(二叉树深度优先遍历dfs的应用) 题解

    剑指Offer 面试题39:二叉树的深度(高度) 题目:输入一棵二叉树的根结点,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度.例如:输入二叉树 ...

  9. 【C++】基于邻接矩阵的图的深度优先遍历(DFS)和广度优先遍历(BFS)

    写在前面:本博客为本人原创,严禁任何形式的转载!本博客只允许放在博客园(.cnblogs.com),如果您在其他网站看到这篇博文,请通过下面这个唯一的合法链接转到原文! 本博客全网唯一合法URL:ht ...

随机推荐

  1. Linux重启和关机命令

    Linux重启命令: 方式1:shutdown –r now 方式2:reboot Linux关机命令: shutdown –h now

  2. Git学习笔记(2)-创建仓库

    一.Git简介 1.Git是什么 Git是分布式版本控制系统 2.Git有什么特点 (1)Git是分布式的SCM,SVN是集中式的 (2)Git每个历史版本存储完整的文件,SVN存储文件差异 (3)G ...

  3. Object.assign() 对象的扩展

    object.assign()方法用于对象的合并,将源对象的(source)的所有的可枚举属性,复制到目标对象(target) var target = {a:1}; var source1={b:2 ...

  4. 拒绝了对对象 'data'(数据库 'xxx',所有者 'dbo')的 SELECT 权限

    拒绝了对对象 'data'(数据库 'xxx',所有者 'dbo')的 SELECT 权限解决的方法:1>在数据库里相应的用户权限中,把db_denydatareader的复选框的勾去掉.很多初 ...

  5. Linux系统调用--getrusage函数详解

    Linux系统调用--getrusage函数详解 功能描述:     获得进程的相关资源信息.如:用户开销时间,系统开销时间,接收的信号量等等;   用法:    #include <sys/t ...

  6. ASP MVC

    V-view 显示层 C-controller 控制层 M-model 模型 D-database 数据库 S-Service 服务 D-Database/Dao 数据库/访问数据库的方法 View即 ...

  7. docloud后台管理项目(开篇)

    最近朋友做app需要web做后台管理,所以花了一周时间做了这个项目. 废话不多说,开发环境是nginx+php5.3,使用thinkphp框架.是一个医疗器械数据统计的后台,业务功能很简单就是查看用户 ...

  8. CAD绘制单行文字(网页版)

    在CAD设计时,需要绘制文字,用户可以设置设置绘制文字的高度等属性. 主要用到函数说明: _DMxDrawX::DrawText 绘制一个单行文字.详细说明如下: 参数 说明 DOUBLE dPosX ...

  9. 梦想CAD控件系统变量说明

    这里介绍一些常用系统变量有String.double.long.McGePoint3d等类型,其中有部分系统变量是随图纸保存,再次打开时就会读取图纸中的系统变量,有些系统变量不随图纸保存,其作用来控制 ...

  10. vue基础---表单输入绑定

    [一]基础用法 用 v-model 指令在表单 <input>.<textarea> 及 <select> 元素上创建双向数据绑定.它会根据控件类型自动选取正确的方 ...