算法笔记学习---深度优先搜索(DFS)

简介: 算法笔记学习---深度优先搜索(DFS)

深度优先搜索(DFS)
设想我们现在身处一个巨大的迷宫之中,以当前所在位置为起点,沿着一条路向前走,当碰到岔路口的时候,就选择其中一个岔道口前进。如果选择的这个岔路前方是一条死路,就退回到这个岔道口,选择另一个岔路前进。如果岔路中存在新的岔道口,那么依然按上面的方法枚举新岔道口的每一条岔路。这样,只要迷宫存在出口,那么这个方法一定能够找到它。

下面举一个迷宫的例子,分步骤解释如何通过DFS找到最后的出口。

假设每次遇到岔道口都选择最右手边的岔路,直到碰到死胡同才回退到最近的岔道口选择另一条岔路。
image.png

(1)第一条路我们选择了ABDH,走到H发现是个死胡同,于是退回到D;下一个岔路选择I,发现I也是死胡同,于是再次退回到D;再下一个岔路选择J,发现J也是个死胡同,于是再次退回到D,此时D的所有岔路已经全部走完,而且均为死胡同,因此退回到D之前的岔道口B,重新选择岔路。

(2)接下来我们从B开始,选择了岔路E,在岔道口E中我们仍然进行枚举,依次选择了岔路K、L、M,发现均为死胡同,因此退回到E之前的岔道口B,B的两个岔路(D和E)都为死胡同,于是我们又回到了最开始的A,重新选择岔路。

(3)接下来我们从C开始,首先访问第一个岔路F,发现F是个死胡同,再退回到C,然后访问G,发现G是终点。至此。我们找到了从起点到终点的路径,DFS过程结束。

在这个例子中,整个DFS过程中先后访问节点的顺序为ABDHIJEKLMCFG。从这个例子中我们可以看出,DFS以深度为关键词,不遇到死胡同是不会退回到上一个岔道口的,所以我们说,深度优先搜索是一种枚举所有完整路径以遍历所有情况的搜索方法。

使用栈和递归可以更好地实现深度优先搜索,使用非递归也是可以实现DFS的,只不过一般情况下会比递归麻烦,在使用递归时,系统会调用一个叫系统栈的东西来存放递归中每一层的状态,因此使用递归来实现DFS的本质其实还是栈。

为了更好地说明递归的效果,下面我们用DFS的思想来分析斐波拉契数列的过程。

斐波拉契数列:F(0)=1,F(1)=1,F(n)=F(n-1)+F(n-2)
image.png

在递归图中我们可以看到,当n>1,F(n)就有两个分支,即把F(n)当作岔道口;而当n为1或0时,F(1)与F(0)就是迷宫的死胡同,在此处就需要返回结果。这样当遍历完所有路径后,就可以得到F(4)的值了。

抽象成代码,模板如下,这里我们用的是C/C++实现。

void DFS(Vertex V)
{
    visited[V] = true;
    for(V的每个邻接点W)
    {
        if(!visited[w]) DFS(W);
    }
}

下面通过一道例题让大家加深对DFS的理解

有n件物品,每件物品的重量为w[i],价值为c[i]。现在需要选出若干件物品放入一个容量为V的背包中,使得在选入背包的物品重量和不超过容量V的前提下,让背包中物品的价值之和最大,求最大价值。(1<=n<=20)

#include<cstdio>
const int maxn = 30;
int n, v, maxValue = 0;//物品件数,背包容量,最大价值
int w[maxn], c[maxn];//w为每件物品重量,c为每件物品价值
//DFS,index为当前处理的物品编号
//sumW和sumC分别为当前总重量和当前总价值
void DFS(int index,int sumW,int sumC)
{
    if(index == n)
    {
        return ;//已经完成对n件物品的选择
    }
    DFS(index+1,sumW,sumC);//不选第index件物品
    //只有当加入第index件物品后未超过容量V,才能继续
    if(sumW+w[index] <= V)
    {
        if(sumC+c[index]>ans)
        {
            ans+=sumC+c[index];//更新最大价值maxValue
        }
        DFS(index+1,sumW+w[index],sumC+c[index]);//选第index件物品
    }
}

int main() 
{
    scanf("%d %d", &n, &v);
    for (int i = 0; i < n; i++) 
    {
        scanf("%d", &w[i]);//每件物品的重量
    }
    for (int i = 0; i < n; i++) 
    {
        scanf("%d", &c[i]);//每件物品的价值
    }
    DFS(0, 0, 0);//初始时为第0件物品、当前总重量和总价值均为0
    printf("%d\n",maxValue);
    return 0;
}
相关文章
|
6天前
|
负载均衡 算法
架构学习:7种负载均衡算法策略
四层负载均衡包括数据链路层、网络层和应用层负载均衡。数据链路层通过修改MAC地址转发帧;网络层通过改变IP地址实现数据包转发;应用层有多种策略,如轮循、权重轮循、随机、权重随机、一致性哈希、响应速度和最少连接数均衡,确保请求合理分配到服务器,提升性能与稳定性。
63 11
架构学习:7种负载均衡算法策略
|
2月前
|
算法
数据结构之路由表查找算法(深度优先搜索和宽度优先搜索)
在网络通信中,路由表用于指导数据包的传输路径。本文介绍了两种常用的路由表查找算法——深度优先算法(DFS)和宽度优先算法(BFS)。DFS使用栈实现,适合路径问题;BFS使用队列,保证找到最短路径。两者均能有效查找路由信息,但适用场景不同,需根据具体需求选择。文中还提供了这两种算法的核心代码及测试结果,验证了算法的有效性。
131 23
|
2月前
|
存储 算法 安全
2024重生之回溯数据结构与算法系列学习之串(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】
数据结构与算法系列学习之串的定义和基本操作、串的储存结构、基本操作的实现、朴素模式匹配算法、KMP算法等代码举例及图解说明;【含常见的报错问题及其对应的解决方法】你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
2024重生之回溯数据结构与算法系列学习之串(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
【EMNLP2024】基于多轮课程学习的大语言模型蒸馏算法 TAPIR
阿里云人工智能平台 PAI 与复旦大学王鹏教授团队合作,在自然语言处理顶级会议 EMNLP 2024 上发表论文《Distilling Instruction-following Abilities of Large Language Models with Task-aware Curriculum Planning》。
|
2月前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习(8)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
2月前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
2月前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之栈和队列精题汇总(10)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第3章之IKUN和I原达人之数据结构与算法系列学习栈与队列精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
2月前
|
算法 vr&ar 计算机视觉
数据结构之洪水填充算法(DFS)
洪水填充算法是一种基于深度优先搜索(DFS)的图像处理技术,主要用于区域填充和图像分割。通过递归或栈的方式探索图像中的连通区域并进行颜色替换。本文介绍了算法的基本原理、数据结构设计(如链表和栈)、核心代码实现及应用实例,展示了算法在图像编辑等领域的高效性和灵活性。同时,文中也讨论了算法的优缺点,如实现简单但可能存在堆栈溢出的风险等。
84 0
|
4天前
|
算法 数据安全/隐私保护 计算机视觉
基于Retinex算法的图像去雾matlab仿真
本项目展示了基于Retinex算法的图像去雾技术。完整程序运行效果无水印,使用Matlab2022a开发。核心代码包含详细中文注释和操作步骤视频。Retinex理论由Edwin Land提出,旨在分离图像的光照和反射分量,增强图像对比度、颜色和细节,尤其在雾天条件下表现优异,有效解决图像去雾问题。
|
4天前
|
算法 数据可视化 安全
基于DWA优化算法的机器人路径规划matlab仿真
本项目基于DWA优化算法实现机器人路径规划的MATLAB仿真,适用于动态环境下的自主导航。使用MATLAB2022A版本运行,展示路径规划和预测结果。核心代码通过散点图和轨迹图可视化路径点及预测路径。DWA算法通过定义速度空间、采样候选动作并评估其优劣(目标方向性、障碍物距离、速度一致性),实时调整机器人运动参数,确保安全避障并接近目标。

热门文章

最新文章