深度优先搜索的基本模型
一、什么是深度优先搜索
深度优先搜索属于图算法的一种,英文缩写为DFS即Depth First Search.其过程简要来说是对每一个可能的分支路径深入到不能再深入为止,而且每个节点只能访问一次.
举例说明之:下图是一个无向图,如果我们从A点发起深度优先搜索(以下的访问次序并不是唯一的,第二个点既可以是B也可以是C,D),则我们可能得到如下的一个访问过程:A->B->E(没有路了!回溯到A)->C->F->H->G->D(没有路,最终回溯到A,A也没有未访问的相邻节点,本次搜索结束).
简要说明深度优先搜索的特点:每次深度优先搜索的结果必然是图的一个连通分量.深度优先搜索可以从多点发起.如果将每个节点在深度优先搜索过程中的"结束时间"排序(具体做法是创建一个list,然后在每个节点的相邻节点都已被访问的情况下,将该节点加入list结尾,然后逆转整个链表),则我们可以得到所谓的"拓扑排序",即topological sort. [1]
二、代码实现
深度优先搜索基本模型可理解为将1到n的数字进行排序。
以下代码将1到n【n<10】的数字进行排序并将排序结果输出
#include <stdio.h>
int a[10],book[10],n;//定义全局变量,a[]用来放入数字,book[]用来标记数字
int DFS(int step)//定义函数,其中step所排序的第几位
{
int i;
if(step==n+1)//如果所排位数等于n+1说明本次排序完成进行输出
{
for(i=1;i<=n;i++)
{
printf("%d",a[i]);
}
printf("\n");
return 0;
}
for(i=1;i<=n;i++)
{
if(book[i]==0)//如果数字i等于0即数字i未排入,则进行一下步骤
{
a[step]=i;//放入数字i
book[i]=1;//标记数字i,表示其已排入
DFS(step+1);//运用递归进行下一位排序
book[i]=0;//将i释放
}
}
return 0;
}
int main()
{
scanf("%d",&n);
DFS(1);
getchar();getchar();
return 0;
}
注意:
在上示代码中,递归与for循环的巧妙运用可以说是它的灵魂之处,
(自行理解不知道该咋注释)
for(i=1;i<=n;i++)//在理解过程中,要明确n是要排的数字,step是要排的位次
{
if(book[i]==0)
{
a[step]=i;
book[i]=1;
DFS(step+1);
book[i]=0;
}
}
小丑竟是我自己!!!