Depth-First深度优先、Breadth-First广度优先、Iterative Deepening迭代深入、Uniform Cost代价一致搜索算法的规则及基于n叉树的时间复杂度空间复杂度比较

本文主要是介绍Depth-First深度优先、Breadth-First广度优先、Iterative Deepening迭代深入、Uniform Cost代价一致搜索算法的规则及基于n叉树的时间复杂度空间复杂度比较,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Depth-First深度优先、Breadth-First广度优先、Iterative Deepening迭代深入、Uniform Cost代价一致搜索算法

分为两部分介绍:

  1. 四种算法的遍历规则
  2. 基于n叉树的时间复杂度与空间复杂度比较
四种算法的遍历规则

使用下图案例来比较四种算法的遍历规则:
在这里插入图片描述

1. Depth-First Search 深度优先算法

策略:优先遍历最深节点
实现:存贮邻接点使用LIFO stack后进先出的栈

2. Breadth-First Search 广度优先算法

策略:优先遍历最浅的一层节点,从上自下,一层层遍历
实现:存贮邻接点使用FIFO queue先入先出数列

在这里插入图片描述在这里插入图片描述
3. Iterative Deepening迭代加深算法

限制一个深度d1用深度优先算法遍历,如果没有目标
限制一个深度d2用深度优先算法遍历,如果没有目标
限制一个深度d3…

在这里插入图片描述在这里插入图片描述
4. Uniform Cost Search代价一致算法

策略:确定邻接节点的集合,从中选取,优先添加花费最小的节点(注意图三优先选取邻接节点中最小的e,即使目标节点已经邻接表中,图四不同颜色表示邻接节点集合范围)
实现:存贮邻接点使用Priority queue优先级数列(优先级为:累计成本)

在这里插入图片描述在这里插入图片描述
在这里插入图片描述在这里插入图片描述
基于n叉树的时间复杂度与空间复杂度比较

用下图b叉树来比较四种算法的时间复杂度与空间复杂度(b是子节点个数,m是b叉树的层数,总的节点数: 1 + b + b 2 1+b+b^2 1+b+b2+… + b m +b^m +bm = O ( b m ) =O(b^m) =O(bm)
在这里插入图片描述

1. Depth-First Search 深度优先算法

时间复杂度:O( b m b^m bm),考虑最坏情况目标在树的右下角,所以需要遍历所有节点
在这里插入图片描述
空间复杂度:O(bm),空间复杂度也就是存贮邻接点的大小,LIFO stack后进先出的栈的容量,考虑最坏情况如图遍历到m层每一层需要存贮相邻的b个节点,故节点个数为bm
在这里插入图片描述

2. Breadth-First Search 广度优先算法

时间复杂度: O ( b s ) O(b^s) O(bs),引入新变量s,即达到目标的最浅层数,故时间复杂度为遍历目标节点前的所有节点 b s b^s bs
在这里插入图片描述
空间复杂度: O ( b s ) O(b^s) O(bs),邻接节点即每一层,考虑最坏情况在s层时,节点个数为 b s b^s bs
在这里插入图片描述

3. Iterative Deepening迭代加深算法

时间复杂度:O ( b s ) (b^s) (bs),同广度优先算法
空间复杂度: O ( b ∗ s ) O(b*s) O(bs),同深度优先算法,但最差情况由第m层变为找到目标的s层
同时汲取了深度优先算法的空间复杂度优势,及广度优先算法的时间shallow-solution较浅情况优势
在这里插入图片描述

4. Uniform Cost Search代价一致算法

时间复杂度:在这里插入图片描述,C是代价, C ∗ C* C是代价的最优值, ϵ \epsilon ϵ指每一步代价至少为,有效深度(effective depth)大约为层C*/ ϵ \epsilon ϵ
空间复杂度:在这里插入图片描述

在这里插入图片描述在这里插入图片描述

这篇关于Depth-First深度优先、Breadth-First广度优先、Iterative Deepening迭代深入、Uniform Cost代价一致搜索算法的规则及基于n叉树的时间复杂度空间复杂度比较的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/270551

相关文章

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

一文带你深入了解Python中的GeneratorExit异常处理

《一文带你深入了解Python中的GeneratorExit异常处理》GeneratorExit是Python内置的异常,当生成器或协程被强制关闭时,Python解释器会向其发送这个异常,下面我们来看... 目录GeneratorExit:协程世界的死亡通知书什么是GeneratorExit实际中的问题案例

查看Oracle数据库中UNDO表空间的使用情况(最新推荐)

《查看Oracle数据库中UNDO表空间的使用情况(最新推荐)》Oracle数据库中查看UNDO表空间使用情况的4种方法:DBA_TABLESPACES和DBA_DATA_FILES提供基本信息,V$... 目录1. 通过 DBjavascriptA_TABLESPACES 和 DBA_DATA_FILES

最新Spring Security实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)

《最新SpringSecurity实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)》本章节介绍了如何通过SpringSecurity实现从配置自定义登录页面、表单登录处理逻辑的配置,并简单模拟... 目录前言改造准备开始登录页改造自定义用户名密码登陆成功失败跳转问题自定义登出前后端分离适配方案结语前言

Python如何获取域名的SSL证书信息和到期时间

《Python如何获取域名的SSL证书信息和到期时间》在当今互联网时代,SSL证书的重要性不言而喻,它不仅为用户提供了安全的连接,还能提高网站的搜索引擎排名,那我们怎么才能通过Python获取域名的S... 目录了解SSL证书的基本概念使用python库来抓取SSL证书信息安装必要的库编写获取SSL证书信息

Mybatis从3.4.0版本到3.5.7版本的迭代方法实现

《Mybatis从3.4.0版本到3.5.7版本的迭代方法实现》本文主要介绍了Mybatis从3.4.0版本到3.5.7版本的迭代方法实现,包括主要的功能增强、不兼容的更改和修复的错误,具有一定的参考... 目录一、3.4.01、主要的功能增强2、selectCursor example3、不兼容的更改二、

Python中Windows和macOS文件路径格式不一致的解决方法

《Python中Windows和macOS文件路径格式不一致的解决方法》在Python中,Windows和macOS的文件路径字符串格式不一致主要体现在路径分隔符上,这种差异可能导致跨平台代码在处理文... 目录方法 1:使用 os.path 模块方法 2:使用 pathlib 模块(推荐)方法 3:统一使

Redis 内存淘汰策略深度解析(最新推荐)

《Redis内存淘汰策略深度解析(最新推荐)》本文详细探讨了Redis的内存淘汰策略、实现原理、适用场景及最佳实践,介绍了八种内存淘汰策略,包括noeviction、LRU、LFU、TTL、Rand... 目录一、 内存淘汰策略概述二、内存淘汰策略详解2.1 ​noeviction(不淘汰)​2.2 ​LR