栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

LeetCode题解随笔: 回溯算法

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

LeetCode题解随笔: 回溯算法

零、前言

回溯法解决的问题都可以抽象为树形结构(N叉树),回溯法解决的问题都是在集合中递归查找子集,集合的大小构成了树的宽度,递归的深度构成树的深度。【参考:代码随想录】

回溯法模板:

  • 回溯函数模板返回值以及参数
void backtracking(参数)
  • 回溯函数终止条件
if (终止条件) {
    存放结果;
    return;
}
  • 回溯搜索的遍历过程

for (选择:本层集合中元素(树中节点孩子的数量就是集合的大小)) {
    处理节点;
    backtracking(路径,选择列表); // 递归
    回溯,撤销处理结果
}
一、组合 77. 组合
vector> res;
    vector path;
    vector> combine(int n, int k) {
        BackTracking(n, k, 1);
        return res;
    }

    void BackTracking(int n, int k, int start) {
        // 递归终止条件
        if (path.size() == k) {
            res.push_back(path);
            return;
        }
        // 递归逻辑
        for (int i = start; i < n; i++) {
            path.push_back(i);
            BackTracking(n, k, i + 1);
            // 回溯
            path.pop_back();
        }
    }

本题即使采用暴力搜索,也很难完成,因此需要用到回溯法。递归的过程如下图所示(来源:代码随想录):

 递归可以进行枝剪,本题递归中的for循环代码可以进行如下修改:

for (int i = startIndex; i <= n - (k - path.size()) + 1; i++)
216. 组合总和 III
vector> res;
    vector path;
    int sum = 0;
    vector> combinationSum3(int k, int n) {
        BackTracking(k, n, 1);
        return res;
    }

    void BackTracking(int k, int n, int start) {
        if (path.size() == k) {
            if (sum == n) {
                res.push_back(path);
            }
            return;
        }
        for (int i = start; i <= 9; i++) {
            if (i >= n)    return;
            path.push_back(i);
            sum += i;
            BackTracking(k, n, i + 1);
            sum -= i;
            path.pop_back();
        }
    }

 本题与上一题类似,不再赘述。

二、分隔

三、子集

四、排列

五、棋盘问题

六、其它

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/883649.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号