DFS——深度优先搜索的简单易懂入门心得

这篇博客介绍了DFS(深度优先搜索)的基本概念和工作原理。内容包括DFS的含义,为何采用“回头”策略,如何记录路径以避免重复,通过具体代码示例解释DFS在全排列问题中的应用,强调了回头清零和防止重复的重要性,并解答了能否按序输出的问题。
摘要由CSDN通过智能技术生成

这个DFS是什么意思啊?

DFS是深度优先搜索(Depth First Search)的简写。看看百度这个老妖怪的说法:…算了,不看了,它这个妖怪都不知道在说什么。

推荐大家观看这个视频,可以帮助大家对DFS有初步的了解。

为什么它要回头走啊?

这就是这个算法最大的特点:“不撞南墙不回头”!

它就像是一个记性很好的憨憨,这个憨憨要回家,不过回家路上有很多分岔路,只有一条路才能通。

说它憨,是因为它每条路都要走一遍,直到满足条件,才能走出去。走不出去它就要去撞一下墙壁,跺一下脚,再倒回上一个分岔路口,然后再换一条路走。

说它记性好,是因为它能记住每一条走过的路,这样就绝对不会重复。

那它要怎么来记录呢?

目前来说,只能是好记性不如烂笔头咯。

拿出一个数组来记录它现在选择的分岔路;再拿一个数组来记录它走过的路。这样在选择下一个路口的时候,就不会走重复啦!

给我看看具体的例子吧

好的呢!

给你看一个全排列的例子,就是把 1,2,3全排列。

代码:

#include <stdio.h>
#include <iostream>
using namespace std;
int a[101],b[101],n;
void print()
{
   
	int i;
	for(i=1;i<=n;i++)
	{
   
		cout<<a[i]<<' ';
	}
	cout<<endl;
}
inline void dfs(int i) 
{
   
	int j;
	if<
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值