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的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

Maven中生命周期深度解析与实战指南

《Maven中生命周期深度解析与实战指南》这篇文章主要为大家详细介绍了Maven生命周期实战指南,包含核心概念、阶段详解、SpringBoot特化场景及企业级实践建议,希望对大家有一定的帮助... 目录一、Maven 生命周期哲学二、default生命周期核心阶段详解(高频使用)三、clean生命周期核心阶

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则