深度优先搜索知识点(一)

前言

在上一篇文章中,我介绍了图的存储及其相关的知识点,那么在这一片文章,就来介绍一种可以对图进行搜索的方式:深度优先搜索(深搜)

深搜及相关基本概念

搜索概念

在这里,我们要先了解什么是搜索
搜索,其实就是从给定的一个地方开始,通过一定的方法或顺序向下查找所需的元素,逐层深入数据

深搜概念

深度优先搜索(Depth First Search)简称 DFS,
指将当前的元素按照一定顺序,向下搜索,并将搜索来的状态作为新起点继续向下搜索,当无法继续向下搜索时,将会回到上一个状态(回溯),寻找其他方向搜索。按照这种规则,直到找到所需状态或数组便利完毕结束。

白话文就是以递归为原理向下搜索。

存储方式

因为需要不断存入元素,同时回溯时是回到上一个元素,类似于栈“先进后出”的概念,所以用栈来储存
如果不了解或不知道栈,我可能会在之后再发布一篇关于栈的文章,也可以在网络看其他大神的文章

实现方法

基本框架

因为是利用递归的原理,那么我们便可以通过递归函数实现深搜

void dfs(编号){
	if(结束条件){
		执行题目所需步骤
	}
	el
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值