day29|leetcode|C++|491. 非递减子序列|46. 全排列|47. 全排列 II

Leetcode 491. 非递减子序列

链接491. 非递减子序列

thought:

  • 设 stack 中最后一个值的位置为 last。如果 stack 为空,则 last = -1。
    设当前正在处理的位置为 pos。
  • 如果在 nums 的子区间 [last+1, pos) 中,存在和 nums[pos] 相同的值,则当前 nums[pos] 必须丢弃,不然会产生重复的子序列。

完整C++代码如下

cpp 复制代码
class Solution {
public:
    vector<vector<int>> findSubsequences(vector<int>& nums) {
        vector<vector<int>> res;
        vector<int> path;
        backtracking(res, nums, path, 0);
        return res;
    }

private:
    void backtracking(vector<vector<int>>& res, vector<int>& nums, vector<int>& path, int start) {
        if (path.size() >= 2) // 如果当前递增子序列长度大于等于2,则将其加入结果集
            res.push_back(path);

        unordered_set<int> seen; // 用一个集合来记录当前层已经使用过的数字,避免重复
        //注意为当前层
        for (int i = start; i < nums.size(); ++i) {
            if ((!path.empty() && nums[i] < path.back()) || seen.count(nums[i])) // 如果当前数字小于上一个数字(不符合递增)或者已经使用过,则跳过
                continue;

            seen.insert(nums[i]); // 将当前数字加入集合

            path.push_back(nums[i]); // 将当前数字加入递增序列

            backtracking(res, nums, path, i + 1); // 递归搜索下一个位置

            path.pop_back(); // 回溯,将当前数字从递增序列中删除
        }
    }
};

Leetcode 46. 全排列

链接46. 全排列

thought:

设置bool数组记录当前位置数是否已经使用过,若使用过直接跳过

完整C++代码如下

cpp 复制代码
class Solution {
public:

    vector<vector<int>> permute(vector<int>& nums) {
        vector<int>path;
        vector<vector<int>>res;
        vector<bool>used(nums.size(),false);
        backtracking(nums,path,res,used);
        return res;
    }
    void backtracking(vector<int>& nums,vector<int>&path,vector<vector<int>>&res,vector<bool>&used){
        if(path.size()==nums.size()){
            res.push_back(path);
            return;
        }
        for(int i=0;i<nums.size();i++){
            if(used[i])continue;
            used[i]=true;
            path.push_back(nums[i]);
            backtracking(nums,path,res,used);//递归
            path.pop_back();//回溯
            used[i]=false;//回溯
        }
    }
};

Leetcode 47. 全排列 II

链接47. 全排列 II

cpp 复制代码
class Solution {
private:
    vector<vector<int>> result;
    vector<int> path;
    void backtracking (vector<int>& nums, vector<bool>& used) {
        // 此时说明找到了一组
        if (path.size() == nums.size()) {
            result.push_back(path);
            return;
        }
        for (int i = 0; i < nums.size(); i++) {
            // used[i - 1] == true,说明同一树枝nums[i - 1]使用过
            // used[i - 1] == false,说明同一树层nums[i - 1]使用过
            // 如果同一树层nums[i - 1]使用过则直接跳过
            if (i > 0 && nums[i] == nums[i - 1] && used[i - 1] == false) {
                continue;
            }
            if (used[i] == false) {
                used[i] = true;
                path.push_back(nums[i]);
                backtracking(nums, used);
                path.pop_back();
                used[i] = false;
            }
        }
    }
public:
    vector<vector<int>> permuteUnique(vector<int>& nums) {
        result.clear();
        path.clear();
        sort(nums.begin(), nums.end()); // 排序
        vector<bool> used(nums.size(), false);
        backtracking(nums, used);
        return result;
    }
};
相关推荐
神仙别闹4 分钟前
基于MFC实现的赛车游戏
c++·游戏·mfc
小c君tt12 分钟前
MFC中 error C2440错误分析及解决方法
c++·mfc
小沈熬夜秃头中୧⍤⃝14 分钟前
【贪心算法】No.1---贪心算法(1)
算法·贪心算法
木向1 小时前
leetcode92:反转链表||
数据结构·c++·算法·leetcode·链表
阿阿越1 小时前
算法每日练 -- 双指针篇(持续更新中)
数据结构·c++·算法
hunandede1 小时前
FFmpeg存放压缩后的音视频数据的结构体:AVPacket简介,结构体,函数
c++
skaiuijing1 小时前
Sparrow系列拓展篇:对调度层进行抽象并引入IPC机制信号量
c语言·算法·操作系统·调度算法·操作系统内核
Star Patrick1 小时前
算法训练(leetcode)二刷第十九天 | *39. 组合总和、*40. 组合总和 II、*131. 分割回文串
python·算法·leetcode
hunandede1 小时前
FFmpeg 4.3 音视频-多路H265监控录放C++开发十三:将AVFrame转换成AVPacket。视频编码,AVPacket 重要函数,结构体成员学习
c++·ffmpeg·音视频
武子康2 小时前
大数据-214 数据挖掘 机器学习理论 - KMeans Python 实现 算法验证 sklearn n_clusters labels
大数据·人工智能·python·深度学习·算法·机器学习·数据挖掘