算法 | 剪枝函数以及几种形式&回溯法和分支限界法的区别&算法特性&分支限界法的思想&分支限界法的基本步骤&Prim和Kruscal&回溯法的效率

what is 剪枝函数?

是对该问题能否得到最优解或者可行解的约束

限界函数:最优解

约束函数:可行解


回溯法和分支限界法的区别:

异:

|-------------|-------------|
| 回溯法 | 分支限界法 |
| 一次生成/扩展一个结点 | 一次生成所有的孩子结点 |
| BFS | DFS/最小耗费优先 |
| 找到所有解 | 找到最优解 |

同:

|--------------------------------------------|
| 均需要定义解空间,解空间的组织结构一般是树或者是图 |
| 在解空间图上搜索问题的解 |
| 在搜索前需要确定判断条件,该条件用来判断该结点是否为可行解 |
| 在搜索的过程中,对生成的结点需要进行判断,满足判断条件的保留,不满足的就舍弃 |


算法特性

输入、输出、确定、可行、有限


分支限界法的思想:

从根开始 ,常以广度优先搜索的方式或者是最小耗费优先的方式搜索问题的解空间树,首先把根节点放入活节点表中,然后从活节点表中取出根节点,使其成为扩展节点,一次性生成扩展节点的孩子结点,舍弃那些导致不可行解或者不是最优解的节点,把其他合适的节点放入活节点表中,然后从活节点表中选取下一个扩展节点,一直搜索,直到找到解或者是活节点表为空。


分支限界法的基本步骤

  • 定义解空间
  • 确定解空间的组织结构(一般是树或者是图)
  • 搜索解空间(确定限界函数和约束函数),如果采用优先级队列分支限界法,还要确定优先级确定方式

Prim和Kruscal

Prim:稠密图

Kruscal:稀疏图,边数较小


回溯法的效率

不依赖于:确定解空间的时间

依赖于:满足显约束的值的个数

计算约束函数的时间

计算限界函数的时间

相关推荐
Wect1 分钟前
LeetCode 4. 寻找两个正序数组的中位数:二分优化思路详解
前端·算法·typescript
王哥儿聊AI3 分钟前
微软开源神器MarkItDown:一键把PPT/PDF/Excel转成markdown,LLM直呼内行!
人工智能·深度学习·microsoft·机器学习·开源·powerpoint
ZPC82104 分钟前
moveitcpp 没办法执行的问题
人工智能·pytorch·算法·机器人
智者知已应修善业7 分钟前
【C++非递归剪枝问题凑钱方案数】2024-7-18
c语言·c++·经验分享·笔记·算法·剪枝
郝学胜-神的一滴7 分钟前
Pytorch张量核心运算精讲:从类型转换到数值操作全解析
开发语言·人工智能·pytorch·python·深度学习·程序人生·机器学习
Yolo_TvT9 分钟前
C++:缺省参数
开发语言·c++·算法
进击的小头11 分钟前
第19篇:多个PI控制器串联控制系统设计与参数整定调试实战
python·算法
承渊政道12 分钟前
【优选算法】(实战领略前缀和的真谛)
开发语言·数据结构·c++·笔记·学习·算法
Jul1en_18 分钟前
Java 集合判空方法对比
java·spring boot·算法·spring
泰克生物19 分钟前
噬菌体展示技术结合机器学习:治疗性 TCR 发现的新范式
机器学习·肿瘤免疫治疗·高通量筛选·噬菌体展示技术·功能验证·文库设计