【详细介绍下图搜索算法】

server/2024/10/18 14:25:34/

在这里插入图片描述

🎥博主:程序员不想YY啊
💫CSDN优质创作者,CSDN实力新星,CSDN博客专家
🤗点赞🎈收藏⭐再看💫养成习惯
✨希望本文对您有所裨益,如有不足之处,欢迎在评论区提出指正,让我们共同学习、交流进步!

在这里插入图片描述

🏆图搜索算法

💥图搜索算法是用于在图中搜索从起始节点到目标节点的路径的算法。其核心思想是逐渐探索图,直到找到所需的路径。这里有几种常用的图搜索算法

🏆1. 深度优先搜索 (DFS)
💥深度优先搜索是一种利用回溯思想的搜索算法,它尝试尽可能深地搜索每一条路径。DFS 采用栈来实现搜索过程,通常用递归很容易实现。

🔥算法步骤如下:
🔥a) 从起始节点开始。
🔥b) 访问当前节点,并将其标记为已访问。
🔥c) 对当前节点的所有未访问的邻接节点,递归地调用DFS。
🔥d) 如果路径不存在,回溯到上一个节点。

🏆2. 广度优先搜索 (BFS)
💥 广度优先搜索是一层一层地进行搜索,先搜索离起点最近的节点。BFS 采用队列来实现搜索过程。

🔥算法步骤如下:
🔥a) 创建一个队列 Q,并将起始节点放入队列。
🔥b) 当 Q 不为空时,做以下操作:🔥i) 从 Q 中移除第一个节点(称为“当前节点”)。🔥ii) 访问当前节点,并将其标记为已访问。🔥iii) 将当前节点的所有未访问过的邻接节点加入到 Q 中。

🏆3. A 搜索算法*
💥 A* 是一种启发式搜索算法,它结合了BFS的部分思想和代价评估。A* 选择路径似乎最接近目标的节点来展开。

🔥算法步骤如下:
🔥a) 初始化一个优先队列(开放列表),将起始节点放入其中,并计算其评估函数 f(n) = g(n) + h(n),其中 g(n) 是起始节点到当前节点的实际成本,h(n) 是当前节点到目标的预估成本(启发式函数)。
🔥b) 当优先队列不为空时,做以下操作:🔥i) 从队列中取出 f(n) 最小的节点(称为“当前节点”)。🔥ii) 如果当前节点就是目标节点,返回成功并回溯路径。🔥iii) 否则将当前节点移出队列,考察它的所有邻居,并为每一个邻居更新 f(n) 值,再放入优先队列。

🏆4. 迭代加深搜索 (IDS)
💥 IDS 结合了深度优先搜索的空间效率和广度优先搜索的完备性(总是能找到一个解)。它通过限制深度进行重复的深度优先搜索。

🔥算法步骤如下:
🔥a) 对于深度限制从 0 开始逐渐增加的每一个值 d:🔥i) 执行深度限制为 d 的深度优先搜索。🔥ii) 如果在当前深度没有找到目标,则增加深度限制,重复搜索。

💥每种算法都有其适应的场景和优缺点。例如,DFS适用于空间受限的情况,而BFS可以快速找到最短路径,A* 则在知道某些启发式信息时效率更高。在选择算法时,需要根据实际应用的需求和图的特性来做出决定。


http://www.ppmy.cn/server/7936.html

相关文章

【C++】双指针算法:盛最多水的容器

1.题目 2.算法思路 有两种方法: 第一种: 暴力穷举法,就是用两次循环将所有的可能性算出来,然后求出最大值。 这种方法最容易想到,但时间复杂度是O(n^2),一定会超时的! 第二种: …

【webrtc】m114自己实现的PrioritizedPacketQueue及优先级处理

G:\CDN\WEBRTC-DEV\libwebrtc_build\src\modules\pacing\prioritized_packet_queue.h跟m98不同 :webrtc】m98 RoundRobinPacketQueue的优先级处理,m114直接使用taskqueue顺序处理了。甚至自己实现了优先级队列感觉简化了实现,更为清晰 易读,但是去掉了码率低就优先的逻辑。1…

如何利用pg_dump和pg_restore迁移从一个PostgreSQL服务器到另一个服务器,同时保持一致性与高效性?

文章目录 解决方案1. 使用pg_dump导出数据2. 将导出的数据复制到目标服务器3. 使用pg_restore导入数据保持一致性与高效性的策略一致性高效性 示例代码导出数据复制数据到目标服务器在目标服务器上解压并导入数据 PostgreSQL数据库的迁移是一个常见的任务,特别是在升…

《深入浅出.NET框架设计与实现》笔记2——C#源码从编写到执行的流程

中间语言(Intermediate Language,IL) C#编译器在编译时,会将源代码作为输入,并以中间语言形式输入出,该代码保存在*.exe文件中或*.dll文件中。 公共语言运行时(CLR) 可以将IL代码…

北京市工程技术人才职称评价基本标准条件

北京市工程技术人才职称评价基本标准条件链接https://rsj.beijing.gov.cn/ywsite/bjpta/zcps/pstj/202104/P020210427512535371948.pdf类别基本条件业绩条件之一成果备注助理工程师学历和专业工作经历符合下列条件之一:1.硕士研究生毕业后,从事本专业技术…

rmallox勒索病毒威胁网络安全:如何避免数据被锁定

尊敬的读者: 随着信息技术的飞速发展,网络空间的安全问题日益凸显。近年来,一种名为.rmallox的勒索病毒频繁出没,给广大计算机用户带来了严重的困扰。本文将对该病毒进行深入剖析,并探讨相应的应对策略。在面对被勒索…

HarmonyOS NEXT 网格元素交换案例

网格元素交换案例 介绍 直接进行交换和删除元素会给用户带来不好的体验效果,因此需要在此过程中注入一些特色的动画来提升体验效果,本案例通过Grid组件、attributeModifier、以 及animateTo函数实现了拖拽动画和删除动画。 效果图预览 使用说明&#…

Wpf 使用 Prism 实战开发Day21

配置默认首页 当应用程序启动时&#xff0c;默认显示首页 一.实现思路&#xff0c;通过自定义接口来配置应用程序加载完成时&#xff0c;设置默认显示页 步骤1.创建自定义 IConfigureService 接口 namespace MyToDo.Common {/// <summary>/// 配置默认显示页接口/// <…