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

leetcode 674. Longest Continuous Increasing Subsequence

目录

题目描述

第一步,明确并理解dp数组及下标的含义 

第二步,分析明确并理解递推公式

第三步,理解dp数组如何初始化

第四步,理解遍历顺序

代码


题目描述

这是动态规划解决子序列问题的例子。与第300题的唯一区别就是,本题要求子序列是连续的。

第一步,明确并理解dp数组及下标的含义 

        int n = nums.size();
        //nums[0,i]表示从第0个数一直到第i个数(包含第i个数)的子数组,dp[i]表示子数组nums[0,i]中的最长连续递增子序列的长度。
        vector<int> dp(n,1);//所有的dp[i]都初始化为1,含义是nums[i]这一个数自身一定是一个子序列

第二步,分析明确并理解递推公式

给定i,只需要考虑nums[i]和nums[i-1]的大小关系。

            if(nums[i]>nums[i-1])
                dp[i] = dp[i-1] +1;
            else
                dp[i] = 1;

第三步,理解dp数组如何初始化

vector<int> dp(n,1);//所有的dp[i]都初始化为1,含义是nums[i]这一个数自身一定是一个子序列

第四步,理解遍历顺序

dp[i]依赖于dp[i-1],所以对i的遍历应该从小到大。

代码

class Solution {
public:int findLengthOfLCIS(vector<int>& nums) {int n = nums.size();//nums[0,i]表示从第0个数一直到第i个数(包含第i个数)的子数组,dp[i]表示子数组nums[0,i]中的最长连续递增子序列的长度。vector<int> dp(n,1);//所有的dp[i]都初始化为1,含义是nums[i]这一个数自身一定是一个子序列int res = dp[0];for(int i = 1;i < n;i++){if(nums[i]>nums[i-1])dp[i] = dp[i-1] +1;elsedp[i] = 1;if(dp[i] > res)res = dp[i];}return res;}
};

可以发现,求dp[i]时候,只需要知道dp[i-1]即可,i-1之前的不再需要。因此可以不用数组,改用两个变量。

class Solution {
public:int findLengthOfLCIS(vector<int>& nums) {int n = nums.size();int dp_i_1 = 1;int dp_i = 1;int res = dp_i_1;for(int i = 1;i < n;i++){if(nums[i]>nums[i-1])dp_i = dp_i_1 +1;elsedp_i = 1;if(dp_i > res)res = dp_i;dp_i_1 = dp_i;}return res;}
};

http://www.mrgr.cn/news/99065.html

相关文章:

  • Unity webgl 获取图片或视频数据
  • leetcode 300. Longest Increasing Subsequence
  • AI分析师
  • 爬虫入门学习
  • 计算机网络八股——HTTP协议与HTTPS协议
  • 杨校老师课堂之C++入门练习题梳理
  • 【刷题Day20】TCP和UDP(浅)
  • Ubuntu20.04下Docker方案实现多平台SDK编译
  • 信创开发:开启信息自主创新、国产替代新时代
  • pgsql中使用jsonb的mybatis-plus和Spring Data JPA的配置
  • MLA(多头潜在注意力)原理概述
  • js day3
  • Redis命令——list
  • 将 DeepSeek 集成到 Spring Boot 项目实现通过 AI 对话方式操作后台数据
  • ospf实验
  • 山东科技大学人工智能原理考试回忆复习资料
  • [密码学实战]基于Python的国密算法与通用密码学工具箱
  • 命令update-alternatives
  • 剑指Offer(数据结构与算法面试题精讲)C++版——day15
  • Github 2FA(Two-Factor Authentication/两因素认证)