《图论》——深度优先搜索算法(DFS)

简介: 十大算法之广度优先遍历: 深度优先搜索遍历类似于树的先序遍历。假定给定图G的初态是所有顶点均未被访问过,在G中任选一个顶点i作为遍历的初始点,则深度优先搜索递归调用包含以下操作: (1)访问搜索到的未被访问的邻接点; (2)将此顶点的visited数组元素值置1; (3)搜索该顶点的未被访问的邻接点,若该邻接点存在,则从此邻接点开始进行同样的访问和搜索。

十大算法之广度优先遍历:


深度优先搜索遍历类似于树的先序遍历。假定给定图G的初态是所有顶点均未被访问过,在G中任选一个顶点i作为遍历的初始点,则深度优先搜索递归调用包含以下操作:

1)访问搜索到的未被访问的邻接点;

2)将此顶点的visited数组元素值置1

3)搜索该顶点的未被访问的邻接点,若该邻接点存在,则从此邻接点开始进行同样的访问和搜索。

深度优先搜索DFS可描述为:

1)访问v0顶点;

2)置 visited[v0]=1

3)搜索v0未被访问的邻接点w,若存在邻接点w,则DFS(w)

遍历过程:     

 DFS在访问图中某一起始顶点 v后,由 v 出发,访问它的任一邻接顶点 w1;再从 w1出发,访问与 w1接但还没有访问过的顶点 w2;然后再从 w2出发,进行类似的访问,…如此进行下去,直至到达所有的邻接顶点都被访问过的顶点 u为止。

接着,退回一步,退到前一次刚访问过的顶点,看是否还有其它没有被访问的邻接顶点。如果有,则访问此顶点,之后再从此顶点出发,进行与前述类似的访问;如果没有,就再退回一步进行搜索。重复上述过程,直到连通图中所有顶点都被访问过为止。如下图所示:

           在此小编的代码主要是根据如下图编写个人代码:

         采用的是存放于邻接链表中

        

         0:代表两个结点没有关联;1:代表两个结点有关联

         思路:

        1、定义vet数组存放结点信息;array数组为邻接链表,初始值为0;ifvisit是判断结点是否被访问过,初始值为false

        2、从A开始遍历,找到第一个与之关联的结点,然后从关联的结点开始遍历,直到所有的结点都被访问过

       代码如下:


package Graph;

import java.util.ArrayList;
import java.util.List;

/*
 * 深度优先遍历算法
 * DFS
 */
public class DFS {

	private static Object[] vet; //定义vet数组用来存放顶点信息
	private static int[][] array;  //定义邻接矩阵用来存放图的顶点信息
	private static int vexnum;      //存放边的条数
	private static boolean[] ifvisited; //存放节点是否被访问过
	private static List<Object> list = new ArrayList<Object>();  //定义一个临时的队列用来存放已经被访问过的节点

	public static void main(String[] args) {
		DFS map = new DFS(5); //初始化队列
		Character[] vet = {'A','B','C','D','E'};
		map.addVet(vet);   //添加顶点
		map.addEage(0,1);
		map.addEage(0,4);
		map.addEage(1,3);
		map.addEage(2,3);
		map.addEage(2,4);
		
		System.out.println("深度优先遍历开始...");
		visited(0);
		ifvisited[0]=true;
		map.dfs(0);
	}
	
	//深度优先遍历
	private void dfs(int k) {
		// TODO Auto-generated method stub
		for(int i=0; i< vexnum; i++)
			if(array[k][i] == 1 && !ifvisited[i])//判断是否被访问过,且其值是否为1
			{
				ifvisited[i] = true;
				visited(i);   //添加到被访问过的节点队列
				for(int j=0; j<vexnum; j++)
				{
					if(!ifvisited[j] && array[i][j] ==1)
					{
						ifvisited[j] = true;
						visited(j);
						dfs(j);  //下次循环从vet[j]开始循环
					}
				}
			}
	}

	//往临时队列里添加已经访问过的结点,并输出
	private static void visited(int k) {
		// TODO Auto-generated method stub
		list.add(vet[k]);
		System.out.println("   -> " + vet[k]);
	}

	//构建邻接矩阵,保存边的信息
	private void addEage(int m, int n) {
		// TODO Auto-generated method stub
		if(m!=n){
			array[m][n] =1;
			array[n][m] =1;
		}
		else
			return;
	}
	
	//初始化图的顶点
	private void addVet(Character[] vet2) {
		// TODO Auto-generated method stub
		this.vet = vet2;
	}

	//图的初始化
	public DFS(int num) {
		// TODO Auto-generated constructor stub
		vexnum = num;   //顶点
		vet = new Object[num]; //顶点的信息
		array = new int[num][num];  //边的信息
		ifvisited = new boolean[num]; //是否被访问过
		for(int i =0 ;i< num; i++)    //初始化边
		{
			ifvisited[i] = false;
			for(int j =0;j<num;j++)
				array[i][j]=0;
		}
	}


}

输出为:

深度优先遍历开始...
   -> A
   -> B
   -> D
   -> C
   -> E

相关文章
|
5月前
|
人工智能 运维 算法
基于 C# 深度优先搜索算法的局域网集中管理软件技术剖析
现代化办公环境中,局域网集中管理软件是保障企业网络高效运行、实现资源合理分配以及强化信息安全管控的核心工具。此类软件需应对复杂的网络拓扑结构、海量的设备信息及多样化的用户操作,而数据结构与算法正是支撑其强大功能的基石。本文将深入剖析深度优先搜索(Depth-First Search,DFS)算法,并结合 C# 语言特性,详细阐述其在局域网集中管理软件中的应用与实现。
120 3
|
6月前
|
监控 算法 安全
基于 PHP 语言深度优先搜索算法的局域网网络监控软件研究
在当下数字化时代,局域网作为企业与机构内部信息交互的核心载体,其稳定性与安全性备受关注。局域网网络监控软件随之兴起,成为保障网络正常运转的关键工具。此类软件的高效运行依托于多种数据结构与算法,本文将聚焦深度优先搜索(DFS)算法,探究其在局域网网络监控软件中的应用,并借助 PHP 语言代码示例予以详细阐释。
112 1
|
7月前
|
运维 监控 JavaScript
内网网管软件中基于 Node.js 的深度优先搜索算法剖析
内网网管软件在企业网络中不可或缺,涵盖设备管理、流量监控和安全防护。本文基于Node.js实现深度优先搜索(DFS)算法,解析其在网络拓扑遍历中的应用。通过DFS,可高效获取内网设备连接关系,助力故障排查与网络规划。代码示例展示了图结构的构建及DFS的具体实现,为内网管理提供技术支持。
119 11
|
7月前
|
机器学习/深度学习 算法
算法系列之搜索算法-深度优先搜索DFS
深度优先搜索和广度优先搜索一样,都是对图进行搜索的算法,目的也都是从起点开始搜索,直到到达顶点。深度优先搜索会沿着一条路径不断的往下搜索,直到不能够在继续为止,然后在折返,开始搜索下一条候补路径。
392 62
算法系列之搜索算法-深度优先搜索DFS
|
6月前
|
算法 安全 Java
算法系列之深度优先搜索寻找妖怪和尚过河问题的所有方式
在算法学习中,深度优先搜索(DFS)是一种常用的图搜索算法,通过递归或栈实现,适合路径搜索、连通性、拓扑排序、回溯、生成、环路检测、强连通分量和可达性等问题。本文将介绍如何利用深度优先搜索解决“妖怪和尚过河问题”的所有方式。
138 26
算法系列之深度优先搜索寻找妖怪和尚过河问题的所有方式
|
6月前
|
监控 算法 JavaScript
企业用网络监控软件中的 Node.js 深度优先搜索算法剖析
在数字化办公盛行的当下,企业对网络监控的需求呈显著增长态势。企业级网络监控软件作为维护网络安全、提高办公效率的关键工具,其重要性不言而喻。此类软件需要高效处理复杂的网络拓扑结构与海量网络数据,而算法与数据结构则构成了其核心支撑。本文将深入剖析深度优先搜索(DFS)算法在企业级网络监控软件中的应用,并通过 Node.js 代码示例进行详细阐释。
111 2
|
6月前
|
存储 算法 JavaScript
基于 Node.js 深度优先搜索算法的上网监管软件研究
在数字化时代,网络环境呈现出高度的复杂性与动态性,上网监管软件在维护网络秩序与安全方面的重要性与日俱增。此类软件依托各类数据结构与算法,实现对网络活动的精准监测与高效管理。本文将深度聚焦于深度优先搜索(DFS)算法,并结合 Node.js 编程语言,深入剖析其在上网监管软件中的应用机制与效能。
90 6
|
7月前
|
存储 算法 iOS开发
【狂热算法篇】并查集:探秘图论中的 “连通神器”,解锁动态连通性的神秘力量(通俗易懂版)
【狂热算法篇】并查集:探秘图论中的 “连通神器”,解锁动态连通性的神秘力量(通俗易懂版)
|
7月前
|
存储 算法 测试技术
【狂热算法篇】探秘图论之 Floyd 算法:解锁最短路径的神秘密码(通俗易懂版)
【狂热算法篇】探秘图论之 Floyd 算法:解锁最短路径的神秘密码(通俗易懂版)
|
27天前
|
机器学习/深度学习 算法 新能源
【优化调度】基于matlab粒子群算法求解水火电经济调度优化问题研究(Matlab代码实现)
【优化调度】基于matlab粒子群算法求解水火电经济调度优化问题研究(Matlab代码实现)

热门文章

最新文章