深度优先搜索(DFS)算法遍历图

复制代码
import java.util.*;

public class GraphDFS {
    private int V; // 图中节点的数量
    private List<List<Integer>> adj; // 邻接表表示的图

    public GraphDFS(int v) {
        V = v;
        adj = new ArrayList<List<Integer>>(v);
        for (int i = 0; i < v; ++i)
            adj.add(new ArrayList<Integer>());
    }

    public void addEdge(int v, int w) {
        adj.get(v).add(w);
    }

    public void DFS(int v) {
        boolean[] visited = new boolean[V];
        DFSUtil(v, visited);
    }

    private void DFSUtil(int v, boolean[] visited) {
        visited[v] = true;
        System.out.print(v + " ");

        List<Integer> neighbors = adj.get(v);
        for (int neighbor : neighbors) {
            if (!visited[neighbor]) {
                DFSUtil(neighbor, visited);
            }
        }
    }

    public static void main(String[] args) {
        GraphDFS graph = new GraphDFS(4);

        graph.addEdge(0, 1);
        graph.addEdge(0, 2);
        graph.addEdge(1, 2);
        graph.addEdge(2, 0);
        graph.addEdge(2, 3);
        graph.addEdge(3, 3);

        System.out.println("深度优先遍历结果:");
        graph.DFS(2);
    }
}
  1. GraphDFS 类定义了一个图,使用邻接表来表示图的结构。它有一个构造函数 GraphDFS(int v),用于初始化图,其中 v 是图中节点的数量。
  2. addEdge(int v, int w) 方法用于向图中添加边,将节点 v 和节点 w 之间建立连接。
  3. DFS(int v) 方法是对外公开的深度优先搜索接口,它接受一个起始节点 v 并启动深度优先搜索。
  4. DFSUtil(int v, boolean[] visited) 方法是内部实现深度优先搜索的递归函数。它接受一个节点 v 和一个布尔类型的数组 visited,用于记录节点是否已经被访问过。在该方法中,首先标记当前节点 v 为已访问,然后递归地遍历当前节点的邻居节点,对未访问过的邻居节点再次调用 DFSUtil 方法。
  5. main 方法中,创建了一个图实例 graph,并添加了一些边。然后调用 DFS(2) 方法,从节点 2 开始进行深度优先搜索。
  6. 最后,打印了深度优先遍历的结果。

该代码创建了一个图,其节点数为 4,边的连接关系如下:

  • 节点 0 与节点 1、2 相连
  • 节点 1 与节点 2 相连
  • 节点 2 与节点 0、3 相连
  • 节点 3 与节点 3 相连
相关推荐
BBB努力学习程序设计7 分钟前
Java方法详解:提升代码复用性与可读性的利器
java
BBB努力学习程序设计8 分钟前
Java运算符完全指南:让代码学会“计算”和“判断”
java
用户849137175471643 分钟前
ThreadLocal 源码深度解析:JDK 设计者的“妥协”与“智慧”
java·后端
用户0304805912631 小时前
# 【Maven避坑】源码去哪了?一文看懂 Maven 工程与打包后的目录映射关系
java·后端
v***55341 小时前
springboot使用logback自定义日志
java·spring boot·logback
qq_336313931 小时前
java基础-集合进阶
java·开发语言·windows
稚辉君.MCA_P8_Java1 小时前
Gemini永久会员 归并排序(Merge Sort) 基于分治思想(Divide and Conquer)的高效排序算法
java·linux·算法·spring·排序算法
q***18841 小时前
Spring Boot中的404错误:原因、影响及处理策略
java·spring boot·后端
222you1 小时前
MybatisPlus常用注解
java·开发语言·spring
汤姆Tom1 小时前
前端转战后端:JavaScript 与 Java 对照学习指南 (第一篇 - 深度进阶版)
java·javascript