算法: 无向图的深度优先搜索(dfs)和广度优先搜索(bfs)

本文介绍了无向图的深度优先搜索(DFS)和广度优先搜索(BFS)算法,包括它们的实现、应用场景及性能分析。DFS适用于树的遍历和连通性问题,BFS则用于最短路径查找。在编程实现时,DFS可用递归或迭代,BFS需注意在顶点入队列前进行标记。
摘要由CSDN通过智能技术生成

更新:DFS和BFS是应用广泛而实现简便的算法,但有2个小点需要稍稍注意一下。
对于DFS来说,可以用递归,也可以用迭代。对于一张较大的图,迭代是优于递归的,因为递归要维护一个函数调用栈。小心stackoverflow喔。
对于BFS来说,实现起来需要注意。很容易把标号为1,2的代码写成3的样子。但这其实是不对的,因为x必须在被取出队列之前mark。

    public void BFS(int v)
    {
        Queue<Integer> que = new LinkedList<>();
        que.offer(v);
        marked[v] = true;// 1
        while(!que.isEmpty())
        {
            int w = que.poll();
            //marked[w] = true; // 2
            for(int x:adj(w))
                if(!marked[x])
                {
                    que.offer(x);
                    marked[x] = true;// 3
                }
        }
    }

深度优先搜索(dfs)

深度优先:从图中某个初始顶点v出发,首先访问初始顶点v,然后选择一个与顶点v相邻且没被访问过的顶点w为初始顶点,再从w出发进行深度优先搜索,直到图中与当前顶点v邻接的所有顶点都被访问过为止。显然,这个遍历过程是个递归过程。
应用:
树的前中后序遍历、连通性问题、寻找从顶点v到顶点w的路径等。(见代码中的pathTo()方法)

性能分析:
深度优先搜索标记与起点连通的所有顶点所需的时间和顶点的度数之和成正比。
使用深度优先搜索得到从给定起点到任意标记顶点的路劲所需的时间与路径的长度成正比。

package Graphs;

import java.util.Stack;

public class DFS {
   

    private Graph g;// unDirectedGraph
    private int s;// startVertex
    private boolean[] marked;// 索引位置的顶点是否被访问过
    private int[] from;// 在dfs访问顺序中,该顶点的前一个顶点

    public DFS(Graph g, int s) {
        this.g = g;
        
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值