代码随想录算法训练营 | 回溯算法part04

491.递增子序列

491.递增子序列

cpp 复制代码
class Solution {
private:
    vector<vector<int>> res;
    vector<int> temp;
    void backtracing (vector<int>& nums, int startIndex) {
        if (temp.size() >= 2) {
            res.push_back(temp);
            //return;
        }
        unordered_set<int> uset; // 使用set来对本层元素进行去重
        for (int i = startIndex; i < nums.size(); ++i) {
            if ((!temp.empty() && nums[i] < temp.back()) || uset.find(nums[i]) != uset.end()) {
                continue;
            }
            uset.insert(nums[i]); // 记录这个元素在本层用过了,本层后面不能再用了
            temp.push_back(nums[i]);
            backtracing(nums, i + 1);
            temp.pop_back();
        }
    }
public:
    vector<vector<int>> findSubsequences(vector<int>& nums) {
        backtracing(nums, 0);
        return res;
    }
};

46.全排列

46.全排列

cpp 复制代码
class Solution {
private:
    vector<vector<int>> res;
    vector<int> temp;
    void backtracing (vector<int>& nums) {
        if (temp.size() == nums.size()) {
            res.push_back(temp);
            return;
        }
        for (int i = 0; i < nums.size(); ++i) {
            if (find(temp.begin(), temp.end(), nums[i]) != temp.end()) { // nums 不含重复元素,可以直接判断元素是否被使用
                continue;
            }
            temp.push_back(nums[i]);
            backtracing(nums);
            temp.pop_back();
        }
    }
public:
    vector<vector<int>> permute(vector<int>& nums) {
        backtracing(nums);
        return res;
    }
};

使用used数组存储元素的使用状态

cpp 复制代码
class Solution {
public:
    vector<vector<int>> res;
    vector<int> temp;
    void backtracking(vector<int>& nums, vector<bool>& used){
        if(temp.size() == nums.size()){
            res.push_back(temp);
            return;
        }
        //nums中不含重复元素
        for(int i = 0; i < nums.size(); ++i){
            if (used[i] == true) continue; // temp里已经收录的元素,直接跳过
            used[i] = true;
            temp.push_back(nums[i]);
            backtracking(nums,used);
            temp.pop_back();
            used[i] = false;
        }
    }
    vector<vector<int>> permute(vector<int>& nums) {
        //使用used数组来记录nums中的每一位是否被使用
        vector<bool> used(nums.size(), false);
        backtracking(nums,used);
        return res;
    }
};

47.全排列 II

47.全排列 II

cpp 复制代码
class Solution {
private:
    vector<vector<int>> res;
    vector<int> temp;
    void backtracing(vector<int>& nums, vector<bool>& used) {
        if (temp.size() == nums.size()) {
            res.push_back(temp);
            return;
        }
        for (int i = 0; i < nums.size(); ++i) {
            if((used[i] == true) || (i > 0 && used[i - 1] == false && nums[i] == nums[i - 1])) {
            	// 同一树杈的同一元素 已被使用过
            	// 同一树层 存在元素相等的情况
                continue;
            }
            used[i] = true;
            temp.push_back(nums[i]);
            backtracing(nums, used);
            temp.pop_back();
            used[i] = false;
        }
    }
public:
    vector<vector<int>> permuteUnique(vector<int>& nums) {
        sort(nums.begin(), nums.end());
        vector<bool> used(nums.size(), false);
        backtracing(nums, used);
        return res;
    }
};
相关推荐
西阳未落17 分钟前
LeetCode——双指针(进阶)
c++·算法·leetcode
暴力求解1 小时前
c++类和对象(下)
开发语言·c++·算法
艾莉丝努力练剑1 小时前
【Linux指令 (二)】不止于入门:探索Linux系统核心与指令的深层逻辑,理解Linux系统理论核心概念与基础指令
linux·服务器·数据结构·c++·centos
Mr_WangAndy2 小时前
C++设计模式_结构型模式_外观模式Facade
c++·设计模式·外观模式
FreeBuf_2 小时前
Happy DOM曝CVSS 9.4严重RCE漏洞,PoC已公开(CVE-2025-61927)
java·c语言·c++·python·php
BlackQid2 小时前
深入理解指针Part4——字符、数组与函数指针变量
c++·后端
熬了夜的程序员2 小时前
【LeetCode】69. x 的平方根
开发语言·算法·leetcode·职场和发展·动态规划
Vect__2 小时前
从底层到上层的“外挂”:deque、stack、queue、priority_queue 全面拆解
数据结构·c++
草莓熊Lotso2 小时前
C++ 手写 List 容器实战:从双向链表原理到完整功能落地,附源码与测试验证
开发语言·c++·链表·list
wxin_VXbishe2 小时前
基于SpringBoot的天天商城管理系统的设计与现-计算机毕业设计源码79506
java·c++·spring boot·python·spring·django·php