动态规划——最长非降子序列的长度

本文介绍了如何使用动态规划解决最长非降子序列问题。以序列6, 4, 5, 8, 7, 3, 9为例,最长非降子序列为{4, 5, 8, 9}和{4, 5, 7, 9},长度为4。解题思路是声明一个数组num,其中num[i]表示以arr[i]结尾的最长非降子序列的长度,并通过动态规划的递推式求解。" 133043113,19694754,Python实现IPv4地址有效性检查算法,"['Python', '网络编程', '字符串处理']
摘要由CSDN通过智能技术生成

动态规划——最长非降子序列的长度

题目描述:

要求得到一个数组的以非降排列的子序列的最大长度,其中并不要求子序列中的元素一定是按照数组顺序的连续数值。
以6 , 4 , 5 , 8 , 7 , 3 , 9为例,最长非降子序列为{4,5 , 8 , 9}和{4,5 , 7 , 9},相应的其长度为4。

解题思路:

因为子序列的定义并不要求元素是数组中连续的数,我们也不得而知最长子序列将从哪一个地方开始,所以不能像连续子序列那样用遍历的方式去找到最长子序列的开始位置和结束位置。那么我们能考虑的就是针对数组中每一个元素去确定:当数组游标从开头走到某元素时,以该元素结尾的最长非降子序列的长度是多少。这样我们比较以每一个数组元素结尾的非降子序列的长度就可以得到最大长度。

解题过程:

  1. 声明一个与原数组arr长度一样的数组num, num[i]表示以arr[i]结尾的最长非降子序列的长度
  2. 分析得到动态规划的递推式
    (1)num[0] = 1:以arr[0]=6结尾的子序列{6}的长度为1
    (2)num[1] = 1 : 以arr[1]=4结尾的子序列{4}的长度为1
    (3)num[2] = 2 : 以arr[2]=5结尾的子序列{4,5}的长度为2
    (4)num[3] = 3 : 以arr[3]=8结尾的子序列{4,5,8}的长度为3
    (5)num[4] = 3 : 以arr[4]=7结尾的子序列{4,5,7}的长度为3 <
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值