深度优先搜索(基本模型)

深度优先搜索的基本模型

一、什么是深度优先搜索

深度优先搜索属于图算法的一种,英文缩写为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;
		}
	}

小丑竟是我自己!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值