第二周总结(关于基本搜索算法)

本文主要介绍了基本的搜索算法——深度优先搜索(DFS)和广度优先搜索(BFS)。DFS强调深度优先,采用递归和回溯的方式,常用于求解有多少种解法的问题;而BFS则与队列结合,是一种横向优先的搜索方法,适用于寻找最短路径问题。文章通过实例和伪代码阐述了两种算法的工作原理和实现方式。
摘要由CSDN通过智能技术生成

这周的主题是基本的搜索算法,基于bfs(广度搜索)和dfs(深度搜索)来实现的

在这里简单介绍以下dfs(深度搜索)算法

这里的关键点是递归和回溯

深度优先搜索算法(DFS)是一种用于遍历或者搜索树或图的算法,沿着一些树遍历树的结点,尽可能深的搜索树的分支,当节点的所在边都被探索过,搜索将回溯到发现结点v的那条边的起始结点.这一过程持续到发现原节点可以到达的所有节点位置。

深度优先搜索的步骤分为 1.递归下去 2.回溯上来。顾名思义,深度优先,则是以深度为准则,先一条路走到底,直到达到目标。这里称之为递归下去。

否则既没有达到目标又无路可走了,那么则退回到上一步的状态,走其他路。这便是回溯上来。

下面来结合具体例子来进行理解

这里写图片描述

假设按照以下的顺序来搜索:

1.V0->V1->V4,此时到底尽头,仍然到不了V6,于是原路返回到V1去搜索其他路径;

2.返回到V1后既搜索V2,于是搜索路径是V0->V1->V2->V6,,找到目标节点,返回有解。

这样搜索只是2步就到达了,但是如果用BFS的话就需要多几步。

DFS的核心伪代码(C语言递归方式)

//它的前置条件是标记已经走过的路径,让book
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值