最长上升子序列(Python and C++解法)

题目:

给定一个无序的整数数组,找到其中最长上升子序列的长度。

示例:

输入: [10,9,2,5,3,7,101,18]
输出: 4
解释: 最长的上升子序列是 [2,3,7,101],它的长度是 4。
说明:子序列不同于子串,可以不连续。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-increasing-subsequence

思路:

  采用动态规划。

  定义状态:dp[i] 表示以 nums[i] 这个数为结尾的最长递增子序列的长度。那么最终结果(子序列的最大长度) 应该是 dp 数组中的最大值。

  状态转移:如果要形成一个新的最长递增子序列,那么只需要找到那些结尾比当前数值小的子序列中的最长的一个,然后把当前数值加在后面,此时需要注意,新的最长子序列的长度+1。

Python解法:

复制代码
 1 class Solution:
 2     def lengthOfLIS(self, nums: List[int]) -> int:
 3       Len = len(nums)
 4       if Len == 0:
 5         return 0
 6       dp = [1] * Len  # 子序列的最短长度是1
 7       for i in range(Len):
 8         for j in range(i):
 9           if nums[j] < nums[i]:
10             dp[i] = max(dp[i], dp[j]+1)
11       maxLen = 1
12       for i in range(Len):
13          if dp[i] > maxLen:
14            maxLen = dp[i]
15       return maxLen
复制代码

C++解法:

复制代码
 1 class Solution {
 2 public:
 3     int lengthOfLIS(vector<int>& nums) {
 4       int Len = nums.size();
 5       if(Len == 0)
 6         return 0;
 7       vector<int> dp(Len, 1);  // 子序列的最短长度是1
 8       for(int i = 0; i < Len; i++) {
 9         for(int j = 0; j < i; j++)
10           if(nums[j] < nums[i])
11             dp[i] = max(dp[j]+1, dp[i]);
12       }
13       int maxLen = 1;
14       for(int i = 0; i < Len; i++)
15         if(dp[i] > maxLen)
16           maxLen = dp[i];
17       return maxLen;
18     }
19 };
复制代码
posted @   孔子?孟子?小柱子!  阅读(808)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示