算法——分支限界

学习目标:

  • 掌握算法入门知识

学习内容:

  • 分支限界的定义
  • 例题详细步骤讲解(找牛)

1. 分支限界的定义

分支限界法是一种用于求解 组合优化问题 的算法框架,通过 系统性地搜索解空间树,并结合 剪枝策略 来避免无效搜索,从而高效地找到最优解(如最小化代价或最大化收益)。其核心思想是:

  • 分支(Branch):将当前问题分解为若干子问题(即扩展解空间树的分支)。例如:在旅行商问题(TSP)中,从一个城市出发,分支为所有可能的下一站城市。

  • 限界(Bound):计算每个子问题的 代价下界(对于最小化问题) 或 收益上界(对于最大化问题)。若某分支的当前界限 差于已知最优解,则直接剪枝,不再继续搜索该分支。

队列式分支限界法:将活结点表组织成一个队列,并按照队列先进先出(FIFO)原则选取下一个结点为扩展结点。步骤如下:

(1)将根结点加入活结点队列。
(2)从活结点队中取出队头结点,作为当前扩展结点。
(3)对当前扩展结点,先从左到右地产生它的所有孩子结点,用约束条件检查,把所有满足约束条件的孩子结点加入活结点队列。
(4)重复步骤(2)和(3),直到找到一个解或活结点队列为空为止。

2. 例题详细步骤讲解(找牛)

农夫知道一头牛的位置,想要抓住它。
农夫和牛都位于数轴上,农夫起始位于点N(0<=N<=100000),牛位于K(0<=K<=100000)。假设牛没有意识到农夫的行动,站在原地不动。农夫最少要花多少时间才能抓住牛?
农夫有两种移动方式:
<1> 从X移动到X-1或X+1,每次移动花费一分钟
<2> 从X移动到2*X,每次移动花费一分钟

假设农夫起始位于点2,牛位于7。即N=2,K=7。最右边是8。 如何搜索到一条走到7的路径?
在这里插入图片描述
思路:分支限界法采用广度优先搜索。
初始化Queue = [ (2, 0) ](初始位置 2,步数 0),visited = [0, 0, 1, 0, 0, 0, 0, 0, 0](2 已访问)

(1)当前位置 为2,可能的移动:2 → 1(左移)2 → 3(右移)2 → 4(跳跃)
更新队列:Queue = [ (1,1), (3,1), (4,1) ],visited 标记 1,3,4 为已访问
(2)当前位置 = 1,可能的移动:1 → 0(左移)1 → 2(右移,2 已访问)1 → 2(跳跃,2 已访问)
更新队列:Queue = [ (3,1), (4,1), (0,2) ],visited 标记 0 为已访问
(3)当前位置 = 3,可能的移动:3 → 2(左移,2 已访问)3 → 4(右移,4 已访问)3 → 6(跳跃)
更新队列:Queue = [ (4,1), (0,2), (6,2) ],visited 标记 6 为已访问
(4)当前位置 = 4,可能的移动:4 → 3(左移,3 已访问)4 → 5(右移)4 → 8(跳跃)
更新队列:Queue = [ (0,2), (6,2), (5,2), (8,2) ],visited 标记 5,8 为已访问
(5)当前位置 = 0,可能的移动:0 → -1(左移,超出范围,忽略)0 → 1(右移,1 已访问)0 → 0(跳跃,无意义)
无新位置可扩展,队列更新:Queue = [ (6,2), (5,2), (8,2) ]
(6)当前位置 = 6,可能的移动:6 → 5(左移,5 已访问)6 → 7(右移)6 → 12(跳跃,12 > 8,超出范围(限界))
发现 7 是目标!当前步数:2(从 2→4→6) + 1(从 6→7) = 3 分钟

得到最优路径:2 → 4 → 6 → 7(共 3 分钟)

代码:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>#define MAXN 100000int N, K;
int visited[MAXN + 10]; // 判重标记数组,visited[i]=1表示位置i已经访问过// 定义结构体表示每一步的状态
typedef struct {int x;      // 当前位置int steps;  // 到达当前位置所需的步数
} Step;// 队列结构定义
typedef struct {Step data[MAXN + 10]; // 队列数据存储int front;           // 队首指针int rear;            // 队尾指针
} Queue;// 初始化队列
void initQueue(Queue *q) {q->front = 0;q->rear = -1;
}// 判断队列是否为空
int isEmpty(Queue *q) {return q->front > q->rear;
}// 入队操作
void enqueue(Queue *q, Step s) {if (q->rear < MAXN + 9) { // 防止队列溢出q->data[++(q->rear)] = s;}
}// 出队操作
Step dequeue(Queue *q) {return q->data[(q->front)++];
}int main() {// 输入农夫和牛的位置scanf("%d %d", &N, &K);// 初始化访问标记数组memset(visited, 0, sizeof(visited));Queue q;initQueue(&q);// 将初始状态加入队列enqueue(&q, (Step){N, 0});visited[N] = 1; // 标记初始位置已访问while (!isEmpty(&q)) {Step current = dequeue(&q);// 如果当前位置就是牛的位置,输出步数并结束if (current.x == K) {printf("%d\n", current.steps);return 0;}// 尝试三种可能的移动方式// 1. 向左移动一步if (current.x - 1 >= 0 && !visited[current.x - 1]) {enqueue(&q, (Step){current.x - 1, current.steps + 1});visited[current.x - 1] = 1; // 标记已访问}// 2. 向右移动一步if (current.x + 1 <= MAXN && !visited[current.x + 1]) {enqueue(&q, (Step){current.x + 1, current.steps + 1});visited[current.x + 1] = 1; // 标记已访问}// 3. 跳跃到两倍位置if (current.x * 2 <= MAXN && !visited[current.x * 2]) {enqueue(&q, (Step){current.x * 2, current.steps + 1});visited[current.x * 2] = 1; // 标记已访问}}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/77565.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

对接日本金融市场数据全指南:K线、实时行情与IPO新股

一、日本金融市场特色与数据价值 日本作为全球第三大经济体&#xff0c;其金融市场具有以下显著特点&#xff1a; 成熟稳定&#xff1a;日经225指数包含日本顶级蓝筹股独特交易时段&#xff1a;上午9:00-11:30&#xff0c;下午12:30-15:00&#xff08;JST&#xff09;高流动性…

解决opencv中文路径问题

见cv_imread函数和cv_imwrite函数 import cv2 import os import matplotlib.pyplot as plt from paddleocr import PaddleOCR, draw_ocr import numpy as np import urllib.parse # Add this import statementfrom txt_get import ImageTextExtractor# 初始化OCR&#xff0c;…

Linux中的Vim与Nano编辑器命令详解

&#x1f4e2; 友情提示&#xff1a; 本文由银河易创AI&#xff08;https://ai.eaigx.com&#xff09;平台gpt-4-turbo模型辅助创作完成&#xff0c;旨在提供灵感参考与技术分享&#xff0c;文中代码与命令建议通过官方渠道验证。 在Linux系统中&#xff0c;文本编辑是最常用的…

宝马集团加速 ERP 转型和上云之旅

宝马集团&#xff08;BMW Group&#xff09;作为全球领先的豪华汽车和摩托车制造商&#xff0c;致力于构建更加智能、绿色、人性化的出行体验。为了支持其全球化、数字化业务战略&#xff0c;宝马集团正在进行大规模的 IT 体系升级和 ERP 云转型。该项目以“RISE with SAP S/4H…

大数据学习(105)-Hbase

&#x1f34b;&#x1f34b;大数据学习&#x1f34b;&#x1f34b; &#x1f525;系列专栏&#xff1a; &#x1f451;哲学语录: 用力所能及&#xff0c;改变世界。 &#x1f496;如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏⭐️留言&#x1f4dd;支持一…

【数学建模】

全国大学生数学建模竞赛(CUMCM)历年试题速浏(查看超级方便)_全国大学生数学建模竞赛真题-CSDN博客 高教社杯全国大学生数学建模竞赛历年赛题&#xff08;含解析、评阅&#xff09; - 赛氪教育 年份 赛题 真题 问题类型 对应算法及模型 2023年 A题 定日镜场的优化设计 …

【Python语言基础】18、多态

文章目录 1. 多态1.1 什么是多态1.2 多态实现方式1.3 多态的好处1.4 多态的好处1.5 不同层面的理解1.6 多态的优缺点 1. 多态 在 Python 里&#xff0c;多态是一种非常有用的编程特性&#xff0c;它能让你以统一的方式处理不同类型的对象 1.1 什么是多态 多态就好比在生活中…

AI多模态论文解读:OmniCaptioner:多领域视觉描述生成框架(附脑图)

AIGCmagic社区知识星球是国内首个以AIGC全栈技术与商业变现为主线的学习交流平台&#xff0c;涉及AI绘画、AI视频、大模型、AI多模态、数字人以及全行业AIGC赋能等100应用方向。星球内部包含海量学习资源、专业问答、前沿资讯、内推招聘、AI课程、AIGC模型、AIGC数据集和源码等…

Spring IoC深度解析:掌控Bean存储艺术与分层架构的智慧​​

一、IoC的本质&#xff1a;从"造物主"到"使用者"的思维跃迁 在传统编程中&#xff0c;开发者像"造物主"一样亲手创建每个对象&#xff08;new UserController()&#xff09;&#xff0c;并管理它们的依赖关系。这种方式导致代码高度耦合&#xf…

ubuntu22.04下安装mysql以及mysql-workbench

一、mysql安装以及配置 安装之前先查看是否已将安装mysql: rpm -qa | grep mysql (一)、在线安装 保证网络正常的情况下: 1、更新软件包: sudo apt update 2、安装mysql安装包 查看可以安装的安装包: sudo apt search mysql-server 安装指定安装包: sudo apt i…

第二届数字图像处理与计算机应用国际学术会议(DIPCA 2025)

重要信息 时间&#xff1a;2025年4月25-27日 地点&#xff1a;中国-西安 官网&#xff1a;www.icipca.net&#xff08;了解详情&#xff09; 部分展示 征稿主题 包括但不限于&#xff1a; 图像处理&#xff1a;模式识别、计算机视觉、低级视觉和图像处理、光学技术在图像中的…

【后端开发】Spring MVC阶段总结

文章目录 快捷引入依赖lombok的使用Lombok依赖Lombok使用Lombok注解 三层架构分层的目的MVC与分层的区别三层架构分层的好处 企业命名规范常见命名命名风格介绍大驼峰风格小驼峰风格包名 常见注解Cookie与Session 快捷引入依赖 这个方法可以快捷引入依赖&#xff0c;但是引入依…

FastAPI依赖注入系统及调试技巧

title: FastAPI依赖注入系统及调试技巧 date: 2025/04/11 15:00:50 updated: 2025/04/11 15:00:50 author: cmdragon excerpt: FastAPI的依赖注入系统采用树状结构管理依赖关系,自动解析并执行依赖项。复杂依赖关系可能导致循环依赖、性能问题、逻辑错误和调试困难。使用Fa…

DeepSeek赋能!企业私有化知识库3大搭建方案拆解

最近公司要搭建一个私有化的知识库&#xff0c;通过对比分析&#xff0c;发现企业级私有化知识库搭建有多种方案选型&#xff0c;今天就分享下这几种企业私有化知识库搭建方案。 一、为何选择本地部署&#xff1f; 这个分个人还是企业&#xff0c;如果个人用&#xff0c;其实各…

对称加密与非对称加密与消息摘要算法保证https的数据交互的完整性和保密性

一、对称加密与非对称加密的作用 1. 对称加密 作用&#xff1a; 保密性&#xff1a;对称加密使用相同的密钥对数据进行加密和解密&#xff0c;确保数据在传输过程中不被窃听。效率&#xff1a;对称加密算法&#xff08;如AES&#xff09;计算速度快&#xff0c;适合加密大量数…

程序化广告行业(76/89):行业融资全景剖析与代码应用拓展

程序化广告行业&#xff08;76/89&#xff09;&#xff1a;行业融资全景剖析与代码应用拓展 大家好&#xff01;在之前的文章里&#xff0c;咱们一起了解了程序化广告行业的发展趋势以及PC端和移动端投放的差异。今天&#xff0c;咱们接着深入学习&#xff0c;这次聚焦在程序化…

两个树莓派如何通过wifi direct传输视频并显示

这里写自定义目录标题 在两台设备上安装必要软件Wi-Fi Direct接收端IP&#xff08;自动发现或静态设置&#xff09;设置摄像头参数显示初始化网络设置 系统架构概述 发送端树莓派&#xff1a;捕获视频&#xff08;摄像头或视频文件&#xff09;→ 编码 → 通过Wi-Fi Direct传输…

ubuntu22.04安装ROS2 humble

参考&#xff1a; https://zhuanlan.zhihu.com/p/702727186 前言&#xff1a; 笔记本安装了ubuntu20.04安装ros一直失败&#xff0c;于是将系统升级为ununut22.04&#xff0c;然后安装ros&#xff0c;根据上面的教程&#xff0c;目前看来是有可能成功的。 系统升级为ununut…

Python 类型转换详解

文章目录 Python 类型转换详解基本类型转换函数1. 转换为整数 (int())2. 转换为浮点数 (float())3. 转换为字符串 (str())4. 转换为布尔值 (bool()) 容器类型转换1. 转换为列表 (list())2. 转换为元组 (tuple())3. 转换为集合 (set())4. 转换为字典 (dict()) 特殊类型转换1. AS…

【Python Requests 库详解】

目录 简介一、安装与导入安装导入 二、发送 HTTP 请求1. GET 请求基本请求URL 参数 2. POST 请求表单数据提交JSON 数据提交文件上传 3. 其他方法PUT 请求示例DELETE 请求示例 三、处理响应1. 响应内容解析文本内容处理二进制内容处理JSON 数据处理 2. 响应状态与头信息状态码检…