深度优先搜索(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 相连
相关推荐
小鑫记得努力5 分钟前
Java类和对象(下篇)
java
binishuaio9 分钟前
Java 第11天 (git版本控制器基础用法)
java·开发语言·git
zz.YE11 分钟前
【Java SE】StringBuffer
java·开发语言
老友@11 分钟前
aspose如何获取PPT放映页“切换”的“持续时间”值
java·powerpoint·aspose
wrx繁星点点26 分钟前
状态模式(State Pattern)详解
java·开发语言·ui·设计模式·状态模式
Upaaui29 分钟前
Aop+自定义注解实现数据字典映射
java
zzzgd81629 分钟前
easyexcel实现自定义的策略类, 最后追加错误提示列, 自适应列宽,自动合并重复单元格, 美化表头
java·excel·表格·easyexcel·导入导出
友善的鸡蛋31 分钟前
解决:使用EasyExcel导入Excel模板时出现数据导入不进去的问题
java·easyexcel·excel导入
星沁城31 分钟前
240. 搜索二维矩阵 II
java·线性代数·算法·leetcode·矩阵
NoneCoder44 分钟前
Java企业级开发系列(1)
java·开发语言·spring·团队开发·开发