力扣-回溯-491 非递减子序列

思路

重点是在树枝去重的时候不能使用之前的used去重了,原因是题目中不允许对序列进行排序,只有排序后才能把相同数字放一起,才能用used数组完成去重

代码

cpp 复制代码
class Solution {
public:
    vector<int> path;
    vector<vector<int>> result;
    void backtracking(vector<int> nums, int startIndex){
        if(path.size() >= 2){
            result.push_back(path);
        }

        unordered_set<int> uset;
        for(int i = startIndex; i < nums.size(); i++){
            if(path.size() > 0 && path[ path.size() - 1] > nums[i]) continue;
            if(uset.find(nums[i]) != uset.end()) continue;
            uset.insert(nums[i]);
            path.push_back(nums[i]);
            backtracking(nums, i+1);
            path.pop_back();
        }

        return;
    }
    vector<vector<int>> findSubsequences(vector<int>& nums) {
        path.clear();
        result.clear();
        backtracking(nums, 0);
        return result;
    }
};
相关推荐
w-w0w-w1 天前
C++中vector的操作和简单实现
开发语言·数据结构·c++
l1t1 天前
郭其先生利用DeepSeek实现的PostgreSQL递归CTE实现DFS写法
sql·算法·postgresql·深度优先
橘颂TA1 天前
【剑斩OFFER】算法的暴力美学——力扣 227 题:基本计算机Ⅱ
c++·算法·leetcode·职场和发展·结构于算法
信奥卷王1 天前
2025年12月GESPC++二级真题解析(含视频)
算法
Z1Jxxx1 天前
输入n个数进行排序,要求先按奇偶后按从小到大的顺序排序
数据结构·算法
乐迪信息1 天前
乐迪信息:船体AI烟火检测,24小时火灾自动预警
人工智能·物联网·算法·目标检测·语音识别
Z1Jxxx1 天前
整除整除整除
开发语言·c++·算法
Swift社区1 天前
LeetCode 471 编码最短长度的字符串
算法·leetcode·职场和发展
没有天赋那就反复1 天前
JAVA length
java·开发语言·算法
Tisfy1 天前
LeetCode 0712.两个字符串的最小ASCII删除和:反向思维保留最大(动态规划)
算法·leetcode·动态规划·字符串·dp·子序列