深度优先搜索(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 相连
相关推荐
isolusion几秒前
Springboot的创建方式
java·spring boot·后端
zjw_rp29 分钟前
Spring-AOP
java·后端·spring·spring-aop
Oneforlove_twoforjob42 分钟前
【Java基础面试题033】Java泛型的作用是什么?
java·开发语言
TodoCoder1 小时前
【编程思想】CopyOnWrite是如何解决高并发场景中的读写瓶颈?
java·后端·面试
向宇it1 小时前
【从零开始入门unity游戏开发之——C#篇24】C#面向对象继承——万物之父(object)、装箱和拆箱、sealed 密封类
java·开发语言·unity·c#·游戏引擎
小蜗牛慢慢爬行1 小时前
Hibernate、JPA、Spring DATA JPA、Hibernate 代理和架构
java·架构·hibernate
星河梦瑾2 小时前
SpringBoot相关漏洞学习资料
java·经验分享·spring boot·安全
黄名富2 小时前
Redis 附加功能(二)— 自动过期、流水线与事务及Lua脚本
java·数据库·redis·lua
love静思冥想2 小时前
JMeter 使用详解
java·jmeter
言、雲2 小时前
从tryLock()源码来出发,解析Redisson的重试机制和看门狗机制
java·开发语言·数据库