当前位置: 首页 > news >正文

算法设计5_分支限界法

分支限界法

  • 分支限界法常以广度优先或以最小耗费(最大效益)优先的方式搜索问题的解空间树,裁剪那些不能得到最优解的子树以提高搜索效率。

  • 步骤: ① 定义解空间(对解编码); ② 确定解空间的树结构; ③ 按BFS等方式搜索: a.每个活结点仅有一次机会变成扩展结点; b.由扩展结点生成一步可达的新结点; c.在新结点中,删除不可能导出最优解的结点;//限界策略 d.将剩余的新结点加入活动表(队列)中; e.从活动表中选择结点再扩展; //分支策略 f.直至活动表为空;

  • 队列式FIFO分支限界

  • 优先队列分支限界

0-1背包问题

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

装载问题

在这里插入图片描述

TSP问题

在这里插入图片描述

nl代表其当前所走路程的长度,Lb代表所有可行解的下界,即每一个节点的出边之和。 B(0,6)进队,其Lb=6的计算方式:找到邻接矩阵中每一行或者每一列除-1之外最小权值相加,即2+2+1+1=6。

在这里插入图片描述

回溯法与分支限界区别

回溯法与分支限界法

  1. 求解目标不同:一般而言,回溯法的求解目标是找出解空间树中满足约束条件的所有解,而分支限界法的求解目标则是尽快地找出满足约束条件的一个解

  2. 搜索方法不同:回溯法使用深度优先方法搜索,而分支限界一般用宽度优先或最佳优先方法来搜索;

  3. 对扩展结点的扩展方式不同:分支限界法中,每一个活结点只有一次机会成为扩展结点。活结点一旦成为扩展结点,就一次性产生其所有儿子结点

  4. 存储空间的要求不同:分支限界法的存储空间比回溯法大得多,因此当内存容量有限时,回溯法成功的可能性更大。

回溯法与穷举法

穷举法:分解后检查。要将一个解的各个部分全部生成后,才检查是否满足条件,若不满足,则直接放弃该完整解,然后再尝试另一个可能的完整解,它并没有沿着一个可能的完整解的各个部分逐步回退生成解的过程。

回溯法:动态生成解空间。一个解的各个部分是逐步生成的,当发现当前生成的某部分不满足约束条件时,就放弃该步所做的工作,退到上一步进行新的尝试,而不是放弃整个解重来

http://www.lryc.cn/news/500703.html

相关文章:

  • 2025年人工智能专业可以考哪些证书呢?
  • 仿真技术助力高尔夫球打破传统设计局限,实现球杆强大的功能
  • 微前端架构学习笔记
  • DApp开发:从合约到系统快速上线解决方案
  • react 中 useState 中的 set 方法异步解决
  • UAC2.0 speaker——带反馈端点的 USB speaker(16bit 单声道)
  • docker的简单使用
  • Selenium:强大的 Web 自动化测试工具
  • 设计模式 在PLM系统的应用场景介绍
  • C#请求https提示未能为 SSL/TLS 安全通道建立信任关系
  • 【人工智能】GaussDB数据库技术及应用
  • OpenAI12天 –第3天的实时更新,包括 ChatGPT、Sora、o1 等
  • 删除Yocto中build-x9hp_ms_a12_vemmc_ap2/tmp/work/aarch64-sdrv-linux/package后再编译出错问题
  • 2024三掌柜赠书活动第三十五期:Redis 应用实例
  • 观察者模式的理解和实践
  • 查看Windows系统上的Redis服务器是否设置了密码
  • 认识Java中的异常(半成品)
  • 生成SSH秘钥文件
  • wsl2子系统ubuntu发行版位置迁移步骤
  • 协程设计原理与实现
  • 合并区间C和C++的区别、布尔、整型、浮点、指针类型和0做比较、malloc、calloc、realloc的区别
  • Flutter 图片编辑板(一) 事件路由
  • 【Java】—— 图书管理系统
  • 数据库基础入门:从零开始学习数据库的核心概念
  • Y20030002 微信+Java+Jsp+Servlet+MySQL的问卷调查小程序的设计与实现 源代码 配置文档 全套资料
  • ros项目dual_arm_pick-place(urdf文件可视化查看)
  • AI-安全-B站
  • 【C#设计模式(19)——备忘录模式(MementoPattern)】
  • 第三部分:进阶概念 8.事件处理 --[JavaScript 新手村:开启编程之旅的第一步]
  • 工具推荐-js爬取工具