最长上升子序列(两种方法)

博客介绍了如何解决最长上升子序列问题,包括使用动态规划的方法,以及优化后的贪心结合二分搜索的nlogn算法。内容包括问题描述、输入输出样例、解题思路及代码实现。
摘要由CSDN通过智能技术生成

最长上升子序列

题目

设有整数序列b1,b2,b3,…,bm,若存在下标i1<i2<i3< …<in,且bi1<bi2<bi3< …<bin,则称 b1,b2,b3,…,bm中有长度为n的不下降序列bi1 , bi2 ,bi3 ,…,bin 。求序列b1,b2,b3,…,bm中所有长度(n)最大不下降子序列

输入

第一行n
第二行 整数序列

输入样例

10
3 18 7 14 10 12 23 41 16 24

输出

最大长度n和所有长度为n的序列个数

输出样例

6

思路

把每个数与前面的数组成的最长上升子序列的长度记录在一维数组中。 记录的数就是前面小于它的数中最长上升子序列的长度最长的数+1。

(一下内容补于 2020/10/7)
当然,这个只是 n 方的算法,很多题都过不去。
这时候就要用一个贪心加上了二分的 nlogn 算法。
–>链接在这里,点我查看<–

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值