Java图搜索算法详解:探索图论中的奥秘

图搜索算法是图论领域的重要内容,它在解决各种实际问题中起着关键作用。本文将详细介绍几种常见的Java图搜索算法,包括深度优先搜索(DFS)、广度优先搜索(BFS)以及Dijkstra算法,帮助读者深入理解图搜索算法的原理和应用。

1. 深度优先搜索(DFS)

深度优先搜索是一种递归的搜索算法,它从图的某一顶点出发,沿着一条路径尽可能深地搜索,直到到达最远的顶点,然后再回溯到上一个顶点,继续搜索其他路径。DFS通常使用栈来实现,其时间复杂度为O(V+E),其中V是顶点数,E是边数。

java 复制代码
import java.util.*;

public class DepthFirstSearch {
    private boolean[] visited;
    private List<List<Integer>> graph;

    public DepthFirstSearch(int n) {
        visited = new boolean[n];
        graph = new ArrayList<>();
        for (int i = 0; i < n; i++) {
            graph.add(new ArrayList<>());
        }
    }

    public void addEdge(int u, int v) {
        graph.get(u).add(v);
    }

    public void dfs(int u) {
        visited[u] = true;
        System.out.print(u + " ");
        for (int v : graph.get(u)) {
            if (!visited[v]) {
                dfs(v);
            }
        }
    }

    public static void main(String[] args) {
        DepthFirstSearch dfs = new DepthFirstSearch(5);
        dfs.addEdge(0, 1);
        dfs.addEdge(0, 2);
        dfs.addEdge(1, 3);
        dfs.addEdge(1, 4);
        dfs.dfs(0); // 从节点0开始深度优先搜索
    }
}

2. 广度优先搜索(BFS)

广度优先搜索是一种迭代的搜索算法,它从图的某一顶点出发,逐层地搜索,直到找到目标顶点或者遍历完所有顶点。BFS通常使用队列来实现,其时间复杂度同样为O(V+E)。

java 复制代码
import java.util.*;

public class BreadthFirstSearch {
    private boolean[] visited;
    private List<List<Integer>> graph;

    public BreadthFirstSearch(int n) {
        visited = new boolean[n];
        graph = new ArrayList<>();
        for (int i = 0; i < n; i++) {
            graph.add(new ArrayList<>());
        }
    }

    public void addEdge(int u, int v) {
        graph.get(u).add(v);
    }

    public void bfs(int u) {
        Queue<Integer> queue = new LinkedList<>();
        visited[u] = true;
        queue.offer(u);
        while (!queue.isEmpty()) {
            int cur = queue.poll();
            System.out.print(cur + " ");
            for (int v : graph.get(cur)) {
                if (!visited[v]) {
                    visited[v] = true;
                    queue.offer(v);
                }
            }
        }
    }

    public static void main(String[] args) {
        BreadthFirstSearch bfs = new BreadthFirstSearch(5);
        bfs.addEdge(0, 1);
        bfs.addEdge(0, 2);
        bfs.addEdge(1, 3);
        bfs.addEdge(1, 4);
        bfs.bfs(0); // 从节点0开始广度优先搜索
    }
}

3. Dijkstra算法

Dijkstra算法是一种用于计算图中单源最短路径的贪心算法,它通过维护一个优先队列来选择下一个要访问的顶点,并不断更新顶点到源顶点的最短距离。Dijkstra算法适用于边权值非负的有向图或无向图,其时间复杂度为O(V^2),其中V是顶点数。

java 复制代码
import java.util.*;

public class Dijkstra {
    private int[] dist;
    private boolean[] visited;
    private List<List<int[]>> graph;

    public Dijkstra(int n) {
        dist = new int[n];
        visited = new boolean[n];
        Arrays.fill(dist, Integer.MAX_VALUE);
        graph = new ArrayList<>();
        for (int i = 0; i < n; i++) {
            graph.add(new ArrayList<>());
        }
    }

    public void addEdge(int u, int v, int w) {
        graph.get(u).add(new int[] { v, w });
    }

    public void dijkstra(int src) {
        PriorityQueue<int[]> pq = new PriorityQueue<>(Comparator.comparingInt(a -> a[1]));
        dist[src] = 0;
        pq.offer(new int[] { src, 0 });
        while (!pq.isEmpty()) {
            int[] cur = pq.poll();
            int u = cur[0];
            if (visited[u]) continue;
            visited[u] = true;
            for (int[] edge : graph.get(u)) {
                int v = edge[0];
                int w = edge[1];
                if (!visited[v] && dist[u] + w < dist[v]) {
                    dist[v] = dist[u] + w;
                    pq.offer(new int[] { v, dist[v] });
                }
            }
        }
    }

    public static void main(String[] args) {
        Dijkstra dijkstra = new Dijkstra(5);
        dijkstra.addEdge(0, 1, 10);
        dijkstra.addEdge(0, 2, 5);
        dijkstra.addEdge(1, 3, 2);
        dijkstra.addEdge(2, 1, 3);
        dijkstra.addEdge(2, 3, 9);
        dijkstra.dijkstra(0); // 从节点0开始Dijkstra算法
    }
}

结论

Java图搜索算法是图论中的重要内容,掌握这些算法对于解决各种实际问题至关重要。通过本文的介绍和实例演示,读者可以更加深入地理解深度优先搜索、广度优先搜索和Dijkstra算法的原理和应用,为解决实际问题提供了强有力的工具和思路。

感谢您阅读本文,欢迎"一键三连"。作者定会不负众望,按时按量创作出更优质的内容。

❤️ 1. 毕业设计专栏,毕业季咱们不慌,上千款毕业设计等你来选。

相关推荐
周杰伦_Jay8 天前
P2图文解析:算法复杂度
数据结构·算法·链表·哈希算法·图搜索算法
小爬虫程序猿9 天前
利用Python爬虫按图搜索1688商品(拍立淘):开启智能购物新体验
爬虫·python·图搜索算法
数据小小爬虫9 天前
利用Python爬虫按图搜索1688商品(拍立淘)的探索之旅
爬虫·python·图搜索算法
不会玩技术的技术girl9 天前
获取按图搜索淘宝商品(拍立淘)API接口用Java示例解释说明
java·python·图搜索算法
Jason-河山9 天前
利用Java爬虫按图搜索1688商品(拍立淘)的实践指南
java·爬虫·图搜索算法
技术猿1887027835111 天前
阿里巴巴1688 API接口深度解析:商品详情获取与按图搜索商品(拍立淘)实用指南
算法·图搜索算法
我搞slam16 天前
全覆盖路径规划算法之BCD源码实现(The Boustrophedon Cellular Decomposition)
c++·算法·图搜索算法
Macw071 个月前
【知识点】图与图论入门
数据结构·c++·算法·数学建模·蓝桥杯·图论·图搜索算法
程序媛一枚~2 个月前
Python实现有向图及查找
python·图搜索算法
小咖拉眯2 个月前
第十六届蓝桥杯模拟赛第二期题解—Java
java·数据结构·算法·蓝桥杯·图搜索算法