回溯法的小结与概述

本文主要讲解回溯法的要点与细节,按照步骤思考更方便理解

提供通用回溯法的伪代码,末尾

说到回溯算法,其实是和递归密不可分的,只要有回溯,就会有递归


什么是回溯呢?

简单来说:就是回到上一个状态(回到之前状态)

为什么要回到上一个状态呢(仔细看这里)?

因为在一些题目中,当前状态是基于上一个状态构建的(是上一个状态的子集),上一个状态还有别的子集没有遍历到。所以,要返回(回溯)到上一个状态,方便枚举隶属于上个状态的其他子集。


讲到这里,其实就可以明白什么是回溯,为什么要进行回溯了。但是什么时候使用回溯呢,我们举几个例子:

  • 组合问题:{1,2,3,4} 中找出大小为2的组合(不强调顺序)
  • 排列问题:{1,2,3,4} 按照升序的全排列,有多少排列方式(强调顺序)
  • 切割问题:字符串按照一定规则有几种切割方式
  • 子集问题:一个集合中有多少符合条件的子集
  • 棋盘问题:N皇后,解数独

回溯算法是类似于数的结构,我们在解题时可以把一个个元素想象成数的节点

由于回溯的本质就是找到给定集合的子集,所以给定的集合就构成了数的宽度,而递归则是树的深度(类比一下二叉树), 所以回溯算法代码的组成就是for循环+递归

for循环就是遍历每层集合区间,可以理解一个节点有多少个孩子,这个for循环就执行多少次。

backtracking这里自己调用自己,实现递归。

横向for循环------------------------------------------------------------------------>>

纵向 {1, 2, 3, 4}

递归 {2,3,4} || {3,4} || {4} || { }

| {3,4} | {4} | { } || 。。。|| 。。 ||。。。

|

|

V //模拟组合问题

下面是回溯的代码模板

复制代码
void backtracking(参数) {
    if (终止条件) {   //符合我们的结果收集规则时,就存放
        存放结果;
        return;
    }

    for (选择:本层集合中元素(树中节点孩子的数量就是集合的大小)) {
        处理节点;
        backtracking(路径,选择列表); // 递归
        回溯操作,撤销处理结果; //返回上一个节点(上一个状态)
    }
}
相关推荐
W是笔名3 分钟前
python___容器类型的数据___序列
开发语言·python
Devin~Y3 分钟前
抖音级短视频推荐与直播带货平台面试实战:从 Java 微服务到 RAG 智能客服全链路解析
java·spring boot·redis·spring cloud·kafka·agent·rag
☆cwlulu4 分钟前
try-throw-catch异常捕获流程
开发语言·c++
aqi0012 分钟前
15天学会AI应用开发(十一)从TXT文件构建RAG知识库
人工智能·python·大模型·ai编程·ai应用
帅次13 分钟前
Android 高级工程师面试:Java 多线程与并发 近1年高频追问 22 题
android·java·面试
要开心吖ZSH16 分钟前
Java事务与MySQL事务的关系及MVCC通俗解析
java·开发语言·mysql·mvcc
汤姆yu17 分钟前
macOS系统下Aider完整安装、配置与实战使用教程
大数据·人工智能·算法·macos·github·copilot
放弃 治疗18 分钟前
Windows 11系统 最新 Launch4j 安装与使用教程:从 JAR 到 EXE 的完整打包指南
java·jar
火星校尉21 分钟前
一场数据基建与消费场景的跨界实验
java·前端·数据库·python·php
Sam092726 分钟前
【AI 算法精讲 14】TF-IDF:词频与逆文档频率
人工智能·python·算法·ai