当前位置: 首页 > article >正文

【算法与数据结构】300、674、LeetCode最长递增子序列 最长连续递增序列

文章目录

  • 一、300、最长递增子序列
  • 二、674、最长连续递增序列
  • 三、完整代码

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

一、300、最长递增子序列

在这里插入图片描述

  思路分析

  • 第一步,动态数组的含义。 d p [ i ] dp[i] dp[i]代表 i i i之前包括以 i i i结尾的最长递增子序列的长度。我们在做递增比较的时候,两个子序列分别以 n u m s [ i ] nums[i] nums[i] n u m s [ j ] nums[j] nums[j]作为结尾。
  • 第二步,递推公式。位置i的最长升序子序列等于j从0到i-1各个位置的最长升序子序列 + 1 的最大值。
	if (nums[i] > nums[j]) dp[i] = max(dp[i], dp[j] + 1);
  • 第三步,元素初始化。dp数组中的所有元素至少为1,因此都初始化为1。
  • 第四步,递归顺序。一共有两层循环,外层循环遍历整个nums数组,里层循环遍历 [ 0 , i − 1 ] [0,i-1] [0,i1]的nums数组。如果当前的nums[i]>nums[j]那么我们取 [ 0 , i − 1 ] [0,i-1] [0,i1]中最大的长度作为 d p [ i ] dp[i] dp[i]的值。
  • 第五步,打印结果。 d p [ n u m s . s i z e ( ) − 1 ] dp[nums.size()-1] dp[nums.size()1]未必是最大的,因此需要筛选出最大的结果返回。
	if (dp[i] > result) result = dp[i];

  程序如下

// 300、最长递增子序列
class Solution {
public:
	int lengthOfLIS(vector<int>& nums) {
		vector<int> dp(nums.size(), 1);
		int result = 1;
		for (int i = 1; i < nums.size(); i++) {
			for (int j = 0; j < i; j++) {
				if (nums[i] > nums[j]) dp[i] = max(dp[i], dp[j] + 1);
			}
			if (dp[i] > result) result = dp[i];
		}
		return result;
	}
};

复杂度分析:

  • 时间复杂度: O ( n 2 ) O(n^2) O(n2)
  • 空间复杂度: O ( n ) O(n) O(n)

二、674、最长连续递增序列

在这里插入图片描述

  思路分析:本题和300、LeetCode最长递增子序列类似,区别在于最长子序列从非连续到连续。因为要求连续的递增子序列,那么我们只需要考察连续这个性质,而连续递增只需要对比nums数组中相邻的两个数。

  • 第一步,动态数组的含义。 d p [ i ] dp[i] dp[i]代表 i i i之前包括以 i i i结尾的最长递增子序列的长度。我们在做递增比较的时候,两个子序列分别以 n u m s [ i ] nums[i] nums[i] n u m s [ i − 1 ] nums[i-1] nums[i1]作为结尾。
  • 第二步,递推公式。本题只要一个循环,如果 n u m s [ i ] nums[i] nums[i] 大于 n u m s [ i − 1 ] nums[i-1] nums[i1],那么dp[i] = dp[i - 1] + 1。
	if (nums[i] > nums[i-1]) dp[i] = dp[i - 1] + 1;
  • 第三步,元素初始化。dp数组中的所有元素至少为1,因此都初始化为1。
  • 第四步,递归顺序。循环从 i = 1 i=1 i=1开始。
  • 第五步,打印结果。 d p [ n u m s . s i z e ( ) − 1 ] dp[nums.size()-1] dp[nums.size()1]未必是最大的,因此需要筛选出最大的结果返回。
	if (dp[i] > result) result = dp[i];

  程序如下

// 674、最长连续递增序列
class Solution2 {
public:
	int findLengthOfLCIS(vector<int>& nums) {
		vector<int> dp(nums.size(), 1);
		int result = 1;
		for (int i = 1; i < nums.size(); i++) {
			if (nums[i] > nums[i-1]) dp[i] = dp[i - 1] + 1;
			if (dp[i] > result) result = dp[i];
		}
		return result;
	}
};

复杂度分析:

  • 时间复杂度: O ( n ) O(n) O(n)
  • 空间复杂度: O ( n ) O(n) O(n)

三、完整代码

# include <iostream>
# include <vector>
using namespace std;

// 300、最长递增子序列
class Solution {
public:
	int lengthOfLIS(vector<int>& nums) {
		vector<int> dp(nums.size(), 1);
		int result = 1;
		for (int i = 1; i < nums.size(); i++) {
			for (int j = 0; j < i; j++) {
				if (nums[i] > nums[j]) dp[i] = max(dp[i], dp[j] + 1);
			}
			if (dp[i] > result) result = dp[i];
		}
		return result;
	}
};

// 674、最长连续递增序列
class Solution2 {
public:
	int findLengthOfLCIS(vector<int>& nums) {
		vector<int> dp(nums.size(), 1);
		int result = 1;
		for (int i = 1; i < nums.size(); i++) {
			if (nums[i] > nums[i-1]) dp[i] = dp[i - 1] + 1;
			if (dp[i] > result) result = dp[i];
		}
		return result;
	}
};

int main() {
	vector<int> nums = { 1,3,5,4,7 };
	Solution2 s1;
	int result = s1.findLengthOfLCIS(nums);
	cout << result << endl;
	system("pause");
	return 0;
}

end


http://www.kler.cn/a/227543.html

相关文章:

  • 微信小程序checkbox多选
  • AJAX-入门
  • 《幻兽帕鲁》好玩吗?幻兽帕鲁能在Mac上运行吗?
  • SpringBoot 使用定时任务(SpringTask)
  • 新年“换”新,好音贺岁!快将索尼耳机加入年货之列
  • 2401cmake,学习cmake1
  • 引流技术-通过文件中增加联系方式并传播
  • [SWPUCTF 2021 新生赛]Do_you_know_http
  • 【退役之重学前端】vite, vue3, vue-router, vuex, ES6学习日记
  • 机器学习6-逻辑回归
  • Group velocity(群速度)
  • 使用Go的并发模型
  • 时序预测 | MATLAB实现基于CNN-BiLSTM-AdaBoost卷积双向长短期记忆网络结合AdaBoost时间序列预测
  • 初识webpack(一)概念、入口配置、输出配置、loader等
  • 高并发编程基础-02-线程基础知识说明
  • 字面跳动前端面试题:React Hook为什么不能放在if/循环/嵌套函数里面?
  • 使用PHPStudy搭建Cloudreve网盘服务
  • springboot完成一个线上图片存放地址+实现前后端上传图片+回显
  • 【智慧工业】东胜物联定位与跟踪解决方案,为方案商提供蓝牙网关、信标等物联网智能硬件设备
  • redis存储对象的过期设置在实际项目中的运用案例展示