• 201.回溯算法:全排列(力扣)


    1. class Solution {
    2. public:
    3. vector<int> res; // 用于存储当前排列组合
    4. vectorint>> result; // 用于存储所有的排列组合
    5. void backtracing(vector<int>& nums, vector<bool>& used) {
    6. // 如果当前排列组合的长度等于 nums 的长度,说明找到一个完整的排列组合
    7. if(res.size() == nums.size()) {
    8. result.push_back(res); // 将当前排列组合加入结果集
    9. return; // 结束当前递归
    10. }
    11. // 遍历每一个数字,尝试将其加入当前排列组合
    12. for(int i = 0; i < nums.size(); i++) {
    13. // 如果当前数字已经被使用过,跳过
    14. if(used[i] == true) continue;
    15. // 标记当前数字已使用
    16. used[i] = true;
    17. // 将当前数字加入当前排列组合
    18. res.push_back(nums[i]);
    19. // 递归处理剩余的数字
    20. backtracing(nums, used);
    21. // 回溯,移除最后一个数字,并标记其为未使用
    22. res.pop_back();
    23. used[i] = false;
    24. }
    25. }
    26. vectorint>> permute(vector<int>& nums) {
    27. // 初始化一个布尔向量用于标记数字是否已被使用
    28. vector<bool> used(nums.size(), false);
    29. // 调用回溯函数,开始生成排列组合
    30. backtracing(nums, used);
    31. // 返回所有的排列组合
    32. return result;
    33. }
    34. };

     

    核心思想

    1. 递归与回溯

      • 使用递归函数 backtracing 来逐步生成排列组合。
      • 每次选择一个元素加入当前排列组合 res 中,然后递归处理剩余的元素。
      • 如果当前排列组合的长度等于输入数组的长度,则表示找到一个完整的排列组合,将其加入结果集 result 中。
      • 递归结束后,回退到上一步,移除最后加入的元素,继续尝试其他可能的选择。
    2. 状态变量

      • res:用于存储当前正在构建的排列组合。
      • result:用于存储所有找到的排列组合。
      • used:一个布尔数组,用于标记某个元素是否已经在当前排列组合中使用过,避免重复使用。
    3. 剪枝

      • 通过 used 数组来避免重复使用已经加入到当前排列组合中的元素。
  • 相关阅读:
    你知道 Java 有哪些引用吗?
    04_BFC
    系统性详解Redis操作Hash类型数据(带源码分析及测试结果)
    HIVE 3 使用 MR 引擎多表关联 (JOIN) 导致丢数的问题复现、问题根源及解决方案 (附代码)
    Linux系统架构----LNMP平台部署中部署wordpress
    JS虚拟机JS加密技术:优缺点及案例研究
    20231109-【尚硅谷】3小时Ajax入门到精通学习笔记
    1110 区块反转分数 25
    Prometheus告警
    SGI图像文件格式
  • 原文地址:https://blog.csdn.net/weixin_63779802/article/details/139981645