算法分析·回溯法

回溯法

  • 方法概述
  • 算法框架
  • 问题实例
    • TSP 问题
    • n皇后问题
  • 回溯法效率分析

方法概述

回溯法是一个既带有系统性又带有跳跃性的搜索算法;

  • **系统性:**它在包含问题的所有解的解空间树中,按照深度优先的策略,从根结点出发搜索解空间树。
    跳跃性:算法搜索至解空间树的任一结点时,判断该结点为根的子树是否包含问题的解,如果肯定不包含,则跳过以该结点为根的子树的搜索,逐层向其祖先结点回溯。否则,进入该子树,继续深度优先的策略进行搜索。

这种以深度优先的方式系统地搜索问题的解得算法称为回溯法,它适用于解一些组合数较大的问题。

  • 问题的解向量:回溯法希望一个问题的解能表示成一个𝑛元组 ( 𝑥 1 , 𝑥 2 , … , 𝑥 𝑛 ) (𝑥_1, 𝑥_2, … , 𝑥_𝑛) (x1,x2,,xn)的形式;
  • 显约束:对分量 𝑥 𝑖 𝑥_𝑖 xi的取值限定;
  • 隐约束:为满足问题的解而对不同分量之间施加的约束;
  • 解空间:对于问题的一个实例,解向量满足显式约束条件的所有多元组, 构成了该实
    例的一个解空间。

请添加图片描述

搜索从开始结点(根结点)出发,以深度优先搜索整个解空间。

这个开始结点成为活结点,同时也成为当前的扩展结点。在当前的扩展结点处,搜索向纵深方向移至一个新结点。这个新结点就成为新的活结点,并成为当前扩展结点。

如果在当前的扩展结点处不能再向纵深方向扩展,则当前扩展结点就成为死结点

此时,应往回移动(回溯)至最近的一个活结点处,并使这个活结点成为当前的扩展结点;直到找到一个解或全部解。

请添加图片描述

基本步骤:

① 针对所给问题,定义问题的解空间;
② 确定易于搜索的解空间结构;
③ 以深度优先方式搜索解空间,并在搜索过程中用剪枝函数避免无效搜索。

常用剪枝函数:

① 用约束函数在扩展结点处剪去不满足约束的子树;
② 用限界函数剪去得不到最优解的子树。

二类常见的解空间树

① 子集树:当所给的问题是从𝑛个元素的集合𝑆中找出满足某种性质的子集时,相应的解空间树称为子集树。子集树通常有 2 𝑛 2^𝑛 2n个叶子结点,其总结点个数为 2 𝑛 + 1 − 1 2^{𝑛+1} − 1 2n+11,遍历子集树时间为 Ω ( 2 𝑛 ) Ω(2^𝑛) Ω(2n) 。如0-1背包问题,叶结点数为 2 𝑛 2^𝑛 2n,总结点数 2 𝑛 + 1 2^{𝑛+1} 2n+1
② 排列树:当所给问题是确定𝑛个元素满足某种性质的排列时,相应的解空间树称为排列树。排列树通常有𝑛!个叶子结点,因此,遍历排列树需要 Ω ( 𝑛 ! ) Ω(𝑛!) Ω(n!)的计算时间。如TSP问题,叶结点数为𝑛!,遍历时间为 Ω ( 𝑛 ! ) Ω(𝑛!) Ω(n!)

算法框架

回溯法对解空间作深度优先搜索,因此在一般情况下可用递归函数来实现回溯法:

子集树回溯算法的伪代码为:

Backtrack( int 𝑡 ) //搜索到树的第𝑡层
{ //由第𝑡层向第𝑡 + 1层扩展,确定𝑥[𝑡]的值if 𝑡 > 𝑛 then output( 𝑥 ); //叶子结点是可行解else while( all Xt) do //𝑋𝑡为当前扩展结点的所有可能取值集合{𝑿[𝑡] = 𝑋𝑡中的第𝑖个值;if( Constraint(𝑡) and Bound( 𝑡 ) )	Backtrack(𝑡 + 1);}
}

排列树回溯算法的伪代码为:

Backtrack( int 𝑡 ) //搜索到树的第𝑡层
{ //由第𝑡层向第𝑡 + 1层扩展,确定𝑥[𝑡]的值if 𝑡 > 𝑛 then output( 𝑥 ); //叶子结点是可行解else for i=t to n do{swap(X[t],X[i]);if( Constraint(𝑡) and Bound( 𝑡 ) )	Backtrack(𝑡 + 1);swap(X[t],X[i]);}
}

问题实例

TSP 问题

旅行商问题。

旅行商从起点出发,遍历图中全部节点后回到原点,求最小代价。

一般的深度优先搜索如下所示:
请添加图片描述

  1. 定义解空间:𝑋 = {12341, 12431, 13241, 13421, 14231, 14321}
  2. 构造解空间树;
  3. 从A出发按DFS搜索整棵树。

请添加图片描述

最优解:13241,14231
成本:25

回溯法基本思想:利用排列生成问题的回溯算法Backtrack(2),对𝑥[] = {1, 2, … , 𝑛}的𝑥[2. . 𝑛]进行全排列,则 (𝑥[1] , 𝑥[2]),(𝑥[2], 𝑥[3]) , … , (𝑥[𝑛], 𝑥[1])构成一个回路。在全排列算法的基础上,进行路径计算保存以及进行限界剪枝。

伪代码如下:

main( int n )
{
𝑎[𝑛][𝑛]; 𝑥[𝑛] = {1,2, … , 𝑛}; 
𝑏𝑒𝑠𝑡𝑥[]; cc=0;
𝑏𝑒𝑠𝑡𝑣 = ∞;//bestx保存当前最佳路径,bestv保存当前最优值
input(𝑎); //输入邻接矩阵
TSPBacktrack(2);
output( 𝑏𝑒𝑠𝑡𝑣, 𝑏𝑒𝑠𝑡𝑥[]);
}TSPBacktrack(int i)
{// 𝑐𝑐记录(𝑥[1], 𝑥[2]), … , (𝑥[𝑖 − 1], 𝑥[𝑖])的距离和if(i>n){// 搜索到叶结点,输出可行解与当前解比较if(cc +a[x[n]][1] < bestv or bestv = ∞){bestv = cc+a[x[n]][1];for(j=1;j<= n; j++) bestx[j]= x[j];}
}
else{for(j=i;j<=n;j++)if(cc+a[x[i-1]][x[j]]<bestv or bestv = ∞)// 限界裁剪子树}swap(x[i],x[j]);cc += a[x[i-1]][x[i]];TSPBackstrack(i+1);cc -= a[x[i-1]][x[i]];swap(x[i],x[j]);
}

n皇后问题

为了便于分析,我们取n=4.

问题描述:在4 × 4棋盘上放上4个皇后,使皇后彼此不受攻击。不受攻击的条件是彼此不在同行(列)、斜线上。求出全部的放法。

解表示:

解编码:(𝑥1, 𝑥2, 𝑥3, 𝑥4)四元组,𝑥𝑖表示皇后放在第𝑖行上的列号,如(3,1,2,4);
解空间:{ 𝑥1, 𝑥2, 𝑥3, 𝑥4 |𝑥𝑖 ∈ 𝑆, 𝑖 = 1~4)} 𝑆 = {1,2,3,4}

可行解满足:

  • 显约束:𝑥𝑖 ∈ 𝑆, 𝑖 = 1~4
  • 隐约束: 请添加图片描述

请添加图片描述

递归算法:

请添加图片描述

回溯法效率分析

效率影响因素:
通过前面具体实例的讨论容易看出,回溯算法的效率在很大程度上依赖于以下因素:

  • 产生𝑥[𝑡]的时间;
  • 满足显约束的𝑥[𝑡]值的个数;
  • 计算约束函数constraint的时间;
  • 计算上界函数bound的时间;
  • 满足约束函数和上界函数约束的所有𝑥[𝑘]的个数。

好的约束函数能显著地减少所生成的结点数。但这样的约束函数往往计算量较大。因此,在选择约束函数时通常存在生成结点数与约束函数计算量之间的折衷。

效率提高技巧:

对于许多问题而言,在搜索试探时选取𝑥[𝑖]的值顺序是任意的。在其它条件相当的前提下,让可取值最少的𝑥[𝑖]优先。从图中关于同一问题的2棵不同解空间树,可以体会到这种策略的潜力。

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

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

相关文章

Golang分布式系统开发实践指南

Golang分布式系统开发实践指南 一、为什么选择Golang&#xff1f; ​原生并发模型​ Goroutine和Channel机制天然适合分布式系统的并发需求​高性能编译​ 静态编译生成二进制文件&#xff0c;部署简单&#xff0c;内存占用低​丰富生态​ Go Module管理、标准库支持HTTP/2、…

基于stm32风速风向温湿度和瓦斯检测(仿真+代码)

资料下载地址&#xff1a;基于stm32风速风向温湿度和瓦斯检测 一、项目功能 1.风速&#xff0c;风向&#xff0c;温湿度&#xff0c;瓦斯&#xff0c;报警。 2.可以设置温湿度&#xff0c;瓦斯&#xff0c;风速报警阈值。 3.数据上传到云平台。 二、仿真图 三、程序 #inc…

桃黑黑反斗战

1.编写求解Hanoi汉诺塔的递归算法代码&#xff0c;输出移动过程&#xff0c;并统计总移动次数。 对不同规模的汉诺塔&#xff0c;给出测试的结果 #include <stdio.h> #include <time.h> int moveCount 0; void hanoi(int n,char source,char auxiliary,char targ…

react-native的token认证流程

在 React Native 中实现 Token 认证是移动应用开发中的常见需求&#xff0c;它用于验证用户的身份并授权其访问受保护的 API 资源。 Token 认证的核心流程&#xff1a; 用户登录 (Login): 用户在前端输入用户名和密码。前端将这些凭据发送到后端 API。后端验证凭据。如果验证成…

Dify:详解 docker-compose.yaml配置文件

详解 docker-compose.yaml 配置文件 docker-compose.yaml 是用于定义和运行多容器 Docker 应用的配置文件。下面&#xff0c;我们将详细解释您提供的 docker-compose.yaml 文件&#xff0c;包括各个服务的作用、配置&#xff0c;以及它们与 .env 文件之间的关系。 文件概览 自…

Python基于Django的主观题自动阅卷系统【附源码、文档说明】

博主介绍&#xff1a;✌Java老徐、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&…

今日行情明日机会——20250528

上证指数缩量收小阴线&#xff0c;个股跌多涨少&#xff0c;总体情绪偏差&#xff0c;注意风险为主。 深证指数&#xff0c;缩量收小阴线&#xff0c;连续5天阴线&#xff0c;明后天反弹的概率增大&#xff0c;但仍要注意风险。 2025年5月28日涨停股主要行业方向分析 1. 无人…

基于stm32LORA无线抄表系统仿真

资料下载地址&#xff1a;基于stm32LORA无线抄表系统仿真 1、项目介绍 基于LoRa的无线通信的电力抄表系统&#xff0c;采集节点数据&#xff0c;通过LoRa无线通信进行数据传输&#xff0c;最后再网关节点上显示。 2、仿真图 3、仿真代码 #include "oled.h" #incl…

不同电脑同一个网络ip地址一样吗

不同电脑在连接同一个WiFi时&#xff0c;它们的IP地址会相同吗&#xff1f;相信不少朋友都对这个问题感到好奇&#xff0c;今天我们就来详细探讨一下。 一、基础概念&#xff1a;IP地址的本质与分类 IP地址是分配给网络设备的唯一标识符&#xff0c;用于在互联网或局域网中定位…

CentOS 7 下 Redis 从 5.0 升级至 7.4.3 全流程实践

目录 前言1 查看 Redis 运行情况与配置1.1 查看 Redis 是否正在运行1.2 连接 Redis 服务并获取配置信息1.3 查找 redis.conf 配置文件位置 2 关闭旧版本 Redis 实例2.1 使用客户端命令关闭 Redis2.2 验证 Redis 是否完全关闭 3 升级 GCC 编译环境3.1 检查当前 GCC 版本3.2 安装…

SQLord: 基于反向数据生成和任务拆解的 Text-to-SQL 企业落地方案

曾在Text-to-SQL方向做过深入的研究&#xff0c;以此为基础研发的DataAgent在B2B平台成功落地&#xff0c;因此作为第一作者&#xff0c;在 The Web Conference (WWW’2025, CCF-A) 会议上发表了相关论文&#xff1a; SQLord: A Robust Enterprise Text-to-SQL Solution via R…

内网搭建NTS服务器

内网搭建NTS服务器 关键字 : ntp nts ipv6 NTS 是 Network Time Security&#xff08;网络时间安全&#xff09;的缩写,是 NTP 的一种安全扩展机制。它利用传输层安全&#xff08;TLS&#xff09;和相关数据的认证加密&#xff08;AEAD&#xff09;&#xff0c;为 NTP 的客户…

AD9268、AD9643调试过程中遇到的问题

Ad9268芯片 AD9268是一款双通道、16位、80 MSPS/105 MSPS/125 MSPS模数转换器(ADC)。AD9268旨在支持要求高性能、低成本、小尺寸和多功能的通信应用。双通道ADC内核采用多级差分流水线架构&#xff0c;集成输出纠错逻辑。每个ADC都具有宽带宽、差分采样保持模拟输入放大器&…

用豆包写单元测试

用豆包写单元测试&#xff0c; 输入 vue 模板内容&#xff0c;输入 参考vue模板内容写一个单元测试要求用jest.mock实现构造完成&#xff0c;修复bug。npm run test:unit – tests/unit/views/xxx/xxx.spec.js看下 % Stmts 语句覆盖率&#xff1a;执行到的代码语句占总语句的比…

css样式块重复调用

通译灵码解释。还给了一些示例&#xff0c;包含传参等内容 scss和sass的区别。scss与sass是两种样式编写风格&#xff0c;scss是大括号加;号形式。而sass是缩进的格式使用scss为什么要要安装sass呢。sass是一门css预处理器语言。所以要安装。

【深度学习新浪潮】以图搜地点是如何实现的?(含大模型方案)

1. 以图搜地点的实现方式有哪些? 扫描手机照片中的截图并识别出位置信息,主要有以下几种实现方式: 通过照片元数据获取: 原理:现代智能手机拍摄的照片通常会包含Exif(Exchangeable Image File)元数据。Exif中除了有像素信息之外,还包含了光圈、快门、白平衡、ISO、焦距…

DeepSeek R1 与 V3 的全面对比,两个版本有什么差别?

DeepSeek R1与DeepSeek V3是深度求索&#xff08;DeepSeek&#xff09;公司推出的两款定位不同的大语言模型&#xff0c;界面上用户可选择基础模型(V3)、深度思考(R1)、联网搜索。 基础模型(V3)是DeepSeek的标配,没有勾选默认就是基础模型。为了让用户更清晰地了解两款模型的差…

Spring Boot 深度集成 Ollama 指南:从聊天模型配置到生产级应用开发

Spring Boot 深度集成 Ollama 指南&#xff1a;从聊天模型配置到生产级应用开发 前言 在人工智能应用开发中&#xff0c;大语言模型&#xff08;LLM&#xff09;的本地化部署需求日益增长。Ollama 作为开源的本地LLM运行平台&#xff0c;支持Mistral、LLaMA等主流模型&#x…

查询oracle进程数和会话数进行优化

查看当前参数配置 首先需要查询当前的 processes 和 sessions 参数值&#xff0c;以确定是否需要调整。 SQL SHOW PARAMETER processes; SHOW PARAMETER sessions; 这些命令可以显示当前实例中允许的最大进程数和会话数 查询当前连接数&#xff0c;查询并发会话 SELECT COUNT…

顶会新方向:卡尔曼滤波+目标检测

卡尔曼虑波&#xff0b;目标检测创新结合&#xff0c;新作准确率突破100%! 一个有前景且好发论文的方向:卡尔曼滤波&#xff0b;目标检测! 这种创新结合&#xff0c;得到学术界的广泛认可&#xff0c;多篇成果陆续登上顶会顶刊。例如无人机竞速系统 Swift&#xff0c;登上nat…