【算法与数据结构】491、LeetCode递增子序列

文章目录

所有的LeetCode题解索引,可以看这篇文章------【算法和数据结构】LeetCode题解

一、题目

二、解法

思路分析:本题和【算法与数据结构】78、90、LeetCode子集I, II中90.子集II问题有些类似,但是本题是找出数组中的递增子序列,不能对数组进行排序。因此在去重方面有所不同,本题去重使用了unordered_set无序集合这个类型进行记录使用过的元素。其余部分和子集II问题都类似。

程序如下:

cpp 复制代码
class Solution {
private:
	vector<vector<int>> result;
	vector<int> path;
	void backtracking(const vector<int>& nums, int startIndex) {
		// 不能排序,取数组的有序递增子集
		if (path.size() >= 2) {
			result.push_back(path);
		}
		unordered_set<int> uset;	// 去重的标志集合,用作本层元素的去重,uset不进入递归,不需要进行回溯操作
		for (int i = startIndex; i < nums.size(); i++) {
			// uset.find(nums[i]) != uset.end()是在uset里面寻找nums[i], 如果找到,则返回的索引!= uset.end(),则nums[i]这个元素已经使用过了
			if (!path.empty() && nums[i] < path.back() || uset.find(nums[i]) != uset.end() ) continue;	
			path.push_back(nums[i]);	// 处理节点		
			uset.insert(nums[i]);
			backtracking(nums, i + 1);	// 递归
			path.pop_back();			// 回溯
		}
	}
public:
	vector<vector<int>> findSubsequences(vector<int>& nums) {
		backtracking(nums, 0);
		return result;
	}
};

复杂度分析:

  • 时间复杂度: O ( n ∗ 2 n ) O(n*2^n) O(n∗2n)。
  • 空间复杂度: O ( n ) O(n) O(n)。

三、完整代码

cpp 复制代码
# include <iostream>
# include <string>
# include <vector>
# include <unordered_set>
using namespace std;

class Solution {
private:
	vector<vector<int>> result;
	vector<int> path;
	void backtracking(const vector<int>& nums, int startIndex) {
		// 不能排序,取数组的有序递增子集
		if (path.size() >= 2) {
			result.push_back(path);
		}
		unordered_set<int> uset;	// 去重的标志集合,用作本层元素的去重,uset不进入递归,不需要进行回溯操作
		for (int i = startIndex; i < nums.size(); i++) {
			// uset.find(nums[i]) != uset.end()是在uset里面寻找nums[i], 如果找到,则返回的索引!= uset.end(),则nums[i]这个元素已经使用过了
			if (!path.empty() && nums[i] < path.back() || uset.find(nums[i]) != uset.end() ) continue;	
			path.push_back(nums[i]);	// 处理节点		
			uset.insert(nums[i]);
			backtracking(nums, i + 1);	// 递归
			path.pop_back();			// 回溯
		}
	}
public:
	vector<vector<int>> findSubsequences(vector<int>& nums) {
		backtracking(nums, 0);
		return result;
	}
};

int main() {
	Solution s1;
	//vector<int> nums = { 4,4,3,2,1 };
	vector<int> nums = { 4, 7, 6, 7 };
	vector<vector<int>> result = s1.findSubsequences(nums);
	for (vector<vector<int>>::iterator it = result.begin(); it != result.end(); it++) {
		for (vector<int>::iterator jt = (*it).begin(); jt != (*it).end(); jt++) {
			cout << *jt << " ";
		}
		cout << endl;
	}
	system("pause");
	return 0;
}

end

相关推荐
醇醛酸醚酮酯12 分钟前
std::promise和std::future的使用示例——单线程多链接、多线程单链接
网络·c++·算法
2301_14725836913 分钟前
7月1日作业
java·前端·算法
爱思德学术1 小时前
中国计算机学会(CCF)推荐学术会议-B(交叉/综合/新兴):BIBM 2025
算法
冰糖猕猴桃1 小时前
【Python】进阶 - 数据结构与算法
开发语言·数据结构·python·算法·时间复杂度、空间复杂度·树、二叉树·堆、图
lifallen1 小时前
Paimon vs. HBase:全链路开销对比
java·大数据·数据结构·数据库·算法·flink·hbase
liujing102329292 小时前
Day04_刷题niuke20250703
java·开发语言·算法
2401_881244403 小时前
Treap树
数据结构·算法
乌萨奇也要立志学C++3 小时前
二叉树OJ题(单值树、相同树、找子树、构建和遍历)
数据结构·算法
网安INF3 小时前
深度学习中的逻辑回归:从原理到Python实现
人工智能·python·深度学习·算法·逻辑回归
wsxqaz3 小时前
浏览器原生控件上传PDF导致hash值不同
算法·pdf·哈希算法