深度优先搜索(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 相连
相关推荐
熙客21 分钟前
TiDB:分布式关系型数据库
java·数据库·分布式·tidb
你想考研啊1 小时前
linux安装jdk和tomcat和并自启动
java·linux·tomcat
悟能不能悟3 小时前
java的java.sql.Date和java.util.Date的区别,应该怎么使用
java·开发语言
高山上有一只小老虎4 小时前
java 正则表达式大全
java·正则表达式
_院长大人_5 小时前
设计模式-工厂模式
java·开发语言·设计模式
凌波粒5 小时前
MyBatis完整教程IDEA版(2)--ResultMap/注解/一对多/多对一/lombok/log4j
java·intellij-idea·mybatis
蓝-萧6 小时前
【玩转全栈】----Django基本配置和介绍
java·后端
priority_key6 小时前
排序算法:堆排序、快速排序、归并排序
java·后端·算法·排序算法·归并排序·堆排序·快速排序
汤姆yu7 小时前
基于SpringBoot的动漫周边商场系统的设计与开发
java·spring boot·后端
皮皮林5517 小时前
快速解决 Maven 版本冲突指南 !
java·maven