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

相关推荐
贾斯汀玛尔斯15 分钟前
每天学一个算法--Aho–Corasick 自动机
java·linux·算法
re林檎19 分钟前
八大排序算法(C++实现)
c++·算法·排序算法
淘气包海鸟20 分钟前
雷达度量衡量
人工智能·算法·机器学习·信息与通信
睡觉就不困鸭20 分钟前
第12天 多数元素
算法·哈希算法·散列表
cpp_250144 分钟前
P2639 [USACO09OCT] Bessie‘s Weight Problem G
数据结构·算法·动态规划·题解·洛谷·背包dp
郝学胜-神的一滴1 小时前
[力扣 227] 双栈妙解表达式计算:从思维逻辑到C++实战,吃透反向波兰式底层原理
java·前端·数据结构·c++·算法
LDG_AGI1 小时前
【搜索引擎】Elasticsearch(六):向量搜索深度解析:从参数原理到混合查询实战
人工智能·深度学习·算法·elasticsearch·机器学习·搜索引擎
会编程的土豆1 小时前
【数据结构与算法】二叉树深度
算法·深度优先
knight_9___1 小时前
RAG面试篇9
java·人工智能·python·算法·agent·rag
贾斯汀玛尔斯1 小时前
每天学一个算法--Top-K 查询(Top-K Retrieval)
算法