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

leetcode 300. Longest Increasing Subsequence

目录

题目描述

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

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

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

第四步,理解遍历顺序

代码


题目描述

这是动态规划解决子序列问题的例子。

第一步,明确并理解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,需要对对所有0<=j<i的nums[j]逐个考察

                if(nums[i] > nums[j]){

                    dp[i] = max(dp[j]+1,dp[i]);

                }

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

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

第四步,理解遍历顺序

i的遍历顺序应该从小到大。起止范围是[0,n-1]。

j的遍历顺序从小到大或者从大到小都可以,起止范围是[0,i-1]。

代码

class Solution {
public:int lengthOfLIS(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 maxLen = dp[0];for(int i = 1;i < n;i++){for(int j = 0;j < i;j++){if(nums[i] > nums[j]){dp[i] = max(dp[j]+1,dp[i]);}}if(dp[i] > maxLen)maxLen = dp[i];}return maxLen;}
};
http://www.xdnf.cn/news/367.html

相关文章:

  • Ethan独立开发产品日报 | 2025-04-18
  • Gradle与Idea整合
  • 【Android面试八股文】Android系统架构【一】
  • x-ui重新申请ssl证书失败
  • VSCode安装与环境配置(Mac环境)
  • 智能语音备忘录:SpeechRecognition与gTTS的奇妙融合
  • 桌面应用UI开发方案
  • 【Redis】从单机架构到分布式,回溯架构的成长设计美学
  • 数据结构——快排和归并排序(非递归)
  • arkTs:使用setTimeout / setInterval 实现透明度切换的轮播图
  • 【论文阅读20】-CNN-Attention-BiGRU-滑坡预测(2025-03)
  • 【Linux】深入理解Linux文件系统:从C接口到内核设计哲学
  • InternVL 3的技术深度分析,代码与原理
  • uboot下读取ubifs分区的方法
  • 树莓派超全系列教程文档--(31)config.txt常用选项介绍
  • 【AI News | 20250418】每日AI进展
  • `peft` 和 `transformers` 库 实现 LoRA的 内部计算流程
  • 基础知识-指针
  • 航电系统之通信技术篇
  • 函数与数组---------C语言经典题目(1)
  • EndNote教程 | 使用EndNote管理文献,从下载到使用
  • Shell脚本-变量是什么
  • 《软件设计师》复习笔记(14.1)——面向对象基本概念、分析设计测试
  • Qt文件操作
  • 影楼精修行业浅见-序言
  • 使用人工智能大模型,如何免费快速把文本转成语音,保存mp3文件
  • Ubuntu 修改语言报错Failed to download repository information
  • 2025/4/18 数据库相关基础知识
  • 编程规范之整数运算
  • 进程间通信(IPC)----共享内存