这个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<