全排列与子集算法精解

全排列

46. 全排列 - 力扣(LeetCode)

算法原理讲解:

遇到这种题,就是画决策树,越详细越好,这样后面写代码的时候会清晰

很明显我们需要一个ret数组去存储最终结果

path是一个记录路径的,全局的和函数头的都行

check数组是为了剪枝,因为你无法判断哪个数字用过,所以增加check数组去判断

这里的回溯就是path要恢复现场

剪枝是利用check数组

恢复现场有两种,一种是先恢复现场再返回,一种是回到上层之后再恢复

这里采用第二种,因为每个结点都是回到上层之后由上层恢复,只需要写一遍即可,否则你需要每次return之前都要写恢复现场逻辑,写两遍(叶子结点一遍,其他结点一遍)

cpp 复制代码
class Solution {
public:
    vector<vector<int>> ret;
    vector<int> path;
    bool check[6];
    vector<vector<int>> permute(vector<int>& nums) {
        dfs(nums);
        return ret;
    }
    void dfs(vector<int>&nums){
        if(path.size()==nums.size()){
            ret.push_back(path);
            return;
        }
        for(int i=0;i<nums.size();i++){
            if(check[i]==false){
                path.push_back(nums[i]);
                check[i]=true;
                dfs(nums);
                check[i]=false;
                path.pop_back();
                
            }
        }
    }
};

子集

78. 子集 - 力扣(LeetCode)

算法原理:

解法一:子集就是每个元素选与不选的问题

i的作用就是告诉dfs函数应该从哪个开始选

每一个dfs我们都需要考虑剪枝、回溯、递归出口

解法二:

画决策树,画的过程中发现,每一层当中都要选,选择后一个数字比前一个数字大的

比如,2的下一层要选择21、22、23,但是只有23是合法的,21在前面12选择过,不要重复选择,决策树的过程就是枚举每一种情况,然后剪枝去掉不符合的情况

由于题目当中并没有说明数组是严格递增且每次+1,博主做的时候也以为是这种情况导致做错,

所以本题需要设计函数头的时候传入参数i,这个i的作用就是从哪个下标开始枚举,比如dfs(nums,2),那这次循环需要从下标2的位置开始枚举

cpp 复制代码
class Solution {
public:
    vector<vector<int>> ret;
    // bool check[10];
    vector<int> path;
    vector<vector<int>> subsets(vector<int>& nums) {
        dfs(nums, 0);
        vector<int> Nothing;
        ret.push_back(Nothing);
        return ret;
    }
    void dfs(vector<int>& nums, int i) {
        if (path.size() == nums.size())
            return;

        for (; i < nums.size(); i++) {
            path.push_back(nums[i]);
            ret.push_back(path);
            dfs(nums, i + 1);
            path.pop_back();
        }
    }
};
相关推荐
那个村的李富贵4 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿5 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
琹箐5 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia16 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了6 小时前
数据结构之树(Java实现)
java·算法
算法备案代理6 小时前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.6 小时前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
野犬寒鸦7 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总7 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
rainbow68897 小时前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法