leetCode 494.递增子序列 + 回溯算法 + 图解 + 笔记

给你一个整数数组 nums ,找出并返回所有该数组中不同的递增子序列,递增子序列中 至少有两个元素 。你可以按 任意顺序 返回答案。

数组中可能含有重复元素,如出现两个整数相等,也可以视作递增序列的一种特殊情况。

示例 1:

cpp 复制代码
输入:nums = [4,6,7,7]
输出:[[4,6],[4,6,7],[4,6,7,7],[4,7],[4,7,7],[6,7],[6,7,7],[7,7]]

示例 2:

cpp 复制代码
输入:nums = [4,4,3,2,1]
输出:[[4,4]]

(1) 回溯算法+哈希表

  • 使用 uset 来记录每层递归里已经取过的元素,来避免重复取数
cpp 复制代码
class Solution {
public:
    vector<vector<int>> result;
    vector<int> path;
    void backtracking(vector<int>& nums,int startIndex) {
        if(path.size()>1) {
            result.push_back(path);// 注意这里不要加return,要取树上的节点
        }
        unordered_set<int> uset; // 使用set来对本层元素进行去重
        for(int i=startIndex;i<nums.size();i++) {
            if((!path.empty() && nums[i]<path.back()) || uset.find(nums[i]) != uset.end()) continue;
            uset.insert(nums[i]); // 记录这个元素在本层用过了,本层后面不能再用了
            path.push_back(nums[i]);
            backtracking(nums,i+1);
            path.pop_back();
        }
    }
    vector<vector<int>> findSubsequences(vector<int>& nums) {
        backtracking(nums, 0);
        return result;
    }
};

(2)优化:由于数值范围[-100,100],可以用数组来做哈希,提升效率

cpp 复制代码
int used[201] = {0}; // 这里使用数组来进行去重操作,题目说数值范围[-100, 100]
for (int i = startIndex; i < nums.size(); i++) {
    if ((!path.empty() && nums[i] < path.back()) || used[nums[i] + 100] == 1) {
        continue;
    }
    used[nums[i] + 100] = 1; // 记录这个元素在本层用过了,本层后面不能再用了
    ......
}

参考文章和推荐视频:

代码随想录 (programmercarl.com)https://www.programmercarl.com/0491.%E9%80%92%E5%A2%9E%E5%AD%90%E5%BA%8F%E5%88%97.html#%E4%BC%98%E5%8C%96回溯算法精讲,树层去重与树枝去重 | LeetCode:491.递增子序列_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1EG4y1h78v/?spm_id_from=333.788&vd_source=a934d7fc6f47698a29dac90a922ba5a3

相关推荐
智驱力人工智能6 小时前
基于视觉分析的人脸联动使用手机检测系统 智能安全管理新突破 人脸与手机行为联动检测 多模态融合人脸与手机行为分析模型
算法·安全·目标检测·计算机视觉·智能手机·视觉检测·边缘计算
2301_764441337 小时前
水星热演化核幔耦合数值模拟
python·算法·数学建模
循环过三天7 小时前
3.4、Python-集合
开发语言·笔记·python·学习·算法
priority_key9 小时前
排序算法:堆排序、快速排序、归并排序
java·后端·算法·排序算法·归并排序·堆排序·快速排序
不染尘.10 小时前
2025_11_7_刷题
开发语言·c++·vscode·算法
来荔枝一大筐11 小时前
力扣 寻找两个正序数组的中位数
算法
算法与编程之美11 小时前
理解Java finalize函数
java·开发语言·jvm·算法
地平线开发者11 小时前
LLM 训练基础概念与流程简介
算法·自动驾驶
点云SLAM11 小时前
弱纹理图像特征匹配算法推荐汇总
人工智能·深度学习·算法·计算机视觉·机器人·slam·弱纹理图像特征匹配
星释11 小时前
Rust 练习册 :Matching Brackets与栈数据结构
数据结构·算法·rust