java图搜索算法之DFS与BFS详解

 更新时间:2021年11月09日 08:56:40   作者:爱敲代码的小黄  
这篇文章主要为大家介绍了java数据结构中可以秒杀一切图算法的DFS与BFS作用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助

你好,我是小黄,一名独角兽企业的Java开发工程师。
感谢茫茫人海中我们能够相遇,
俗话说:当你的才华和能力,不足以支撑你的梦想的时候,请静下心来学习,
希望优秀的你可以和我一起学习,一起努力,实现属于自己的梦想。

一、前言

上一篇文章我们提到了关于图的形象化描述方法,不知道大家还有没有印象。没有印象的话,可以去看一下上期的内容

对于图来说,搜索的方法无外乎两种,深度优先搜索(DFS)和广度优先搜索(BFS)

两种搜索算法也不太相同,今天我们就来看一下这两个搜索算法

二、深度优先搜索

我们一提到深度优先搜索,脑子里第一时间想到的就是递归

没错,深搜就是依靠递归的方法来进行的搜索,我们来看一个例题:

在这里插入图片描述

对于上图来说,使用深度优先搜索的路线为:0 -> 3 - > 2 -> 4 -> 5 -> 1

这里不懂深搜的小伙伴可以看下这篇:深度优先搜索

递归版本:

	/**
     * 深度优先搜索
     * 
     * @param node
     * @param set
     */
	public void DFS(Node node, Set<Node> set) {
        if (node == null) {
            return;
        }
        if (!set.contains(node)) {
            set.add(node);
            System.out.print(node.value + " ");
            for (Node node1 : node.nexts) {
                DFS(node1, set);
            }
        }
    }

迭代版本:

	/**
     * 深度优先搜索
     *
     * @param node
     */
	public void DFS(Node node) {
        Stack<Node> stack = new Stack<>();
        Set<Node> set = new HashSet<>();
        stack.add(node);
        set.add(node);
        System.out.print(node.value + " ");
        while (!stack.isEmpty()) {
            Node cur = stack.pop();
            for (Node next : cur.nexts) {
                if (!set.contains(next)) {
                    stack.add(cur); // 用来做记忆化的
                    stack.add(next);
                    System.out.print(next.value + " ");
                    set.add(next);
                    break;
                }
            }
        }
    }

测试结果:

迭代版本:
0 3 2 4 5 1
递归版本:
0 3 2 4 5 1

三、广度优先搜索

对于广度优先搜索的话,简单的来说,像走地图一样,一圈一圈的扩展开来

我们来看一个例题:

在这里插入图片描述

对于上图来说,使用深度优先搜索的路线为:0 -> 3 -> 1 -> 2 -> 4 -> 5

这里不懂广搜的小伙伴可以看下这篇:广度优先搜索

	/**
     * 广度优先搜索
     *
     * @param node
     */
    public static void BFS(Node node) {
        if (node == null) {
            return;
        }
        Queue<Node> queue = new LinkedList<>();
        // 代表是否被使用
        Set<Node> set = new HashSet<>();
        queue.add(node);
        set.add(node);
        while (!queue.isEmpty()) {
            Node cur = queue.poll();
            System.out.print(cur.value + " ");
            for (Node next : cur.nexts) {
                if (!set.contains(next)) {
                    queue.add(next);
                    set.add(next);
                }
            }
        }
    }

四、结语

这期的深度优先搜索和广度优先搜索比较简单

让你对图的搜索大概有个了解,下几期将会讲解一些真实的算法

在算法题中,题目不会单纯的让你求深搜和广搜,经常会和别的一起出现,比如最小生成树等

以上就是java数据结构图算法之DFS与BFS详解的详细内容,更多关于java数据结构图算法DFS与BFS的资料请关注脚本之家其它相关文章!

相关文章

  • Java集合Stack源码详解

    Java集合Stack源码详解

    java工具包中的Stack是继承于Vector(矢量队列)的,由于Vector是通过数组实现的,这就意味着,Stack也是通过数组实现的,而非链表。当然,我们也可以将LinkedList当作栈来使用!
    2018-05-05
  • Java线程池ForkJoinPool(工作窃取算法)的使用

    Java线程池ForkJoinPool(工作窃取算法)的使用

    Fork就是把一个大任务切分为若干个子任务并行地执行,Join就是合并这些子任务的执行结果,最后得到这个大任务的结果。Fork/Join 框架使用的是工作窃取算法。本文主要介绍了ForkJoinPool的使用,需要的可以参考一下
    2022-11-11
  • SpringBoot+MyBatis-Plus实现分页示例

    SpringBoot+MyBatis-Plus实现分页示例

    本文介绍了SpringBoot+MyBatis-Plus实现分页示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-12-12
  • Mybatis使用大于等于或小于等于进行比较

    Mybatis使用大于等于或小于等于进行比较

    本文主要介绍了Mybatis使用大于等于或小于等于进行比较,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • springboot项目启动自动跳转到浏览器的操作代码

    springboot项目启动自动跳转到浏览器的操作代码

    这篇文章主要介绍了springboot项目启动自动跳转到浏览器的操作代码,本文图文实例代码相结合给大家介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • spring redis 如何实现模糊查找key

    spring redis 如何实现模糊查找key

    这篇文章主要介绍了spring redis 如何实现模糊查找key的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • Spring配置动态数据源实现读写分离的方法

    Spring配置动态数据源实现读写分离的方法

    这篇文章主要介绍了利用Spring配置动态数据源实现读写分离的方法,文中通过示例代码介绍的很详细,相信对大家的理解和学习具有一定的参考借鉴价值,藕需要的朋友可以一起学习学习。
    2017-01-01
  • java Socket无法完全接收返回内容的解决方案

    java Socket无法完全接收返回内容的解决方案

    这篇文章主要介绍了java Socket无法完全接收返回内容的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-10-10
  • spring boot项目使用@Async注解的坑

    spring boot项目使用@Async注解的坑

    这篇文章主要为大家介绍了spring boot项目中使用@Async注解遇到的坑示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • Java黑科技:replace首个替换一秒搞定

    Java黑科技:replace首个替换一秒搞定

    要实现只替换第一个匹配项,可以使用Java中的String类的replaceFirst方法,该方法接受两个参数,第一个参数是要替换的字符串或正则表达式,第二个参数是替换后的字符串,需要的朋友可以参考下
    2023-10-10

最新评论