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

C++ 动态规划 最长上升子序列2 朴素做法的优化

给定一个长度为 N
的数列,求数值严格单调递增的子序列的长度最长是多少。

输入格式
第一行包含整数 N

第二行包含 N
个整数,表示完整序列。

输出格式
输出一个整数,表示最大长度。

数据范围
1≤N≤100000

−109≤数列中的数≤109
输入样例:
7
3 1 2 1 8 5 6
输出样例:
4

优化思想:在朴素做法中,比如3121856这个数列,我们发现如果后面一个数能接在3后面的话,也一定能接在1后面,因为1小于3,也就是3就没必要存了,可以只存最小的一个数。

#include <iostream>
#include <algorithm>

using namespace std;

const int N = 100010;
int n;
int a[N];
int q[N]; // 存储所有不同长度的上升子序列的结尾的最小值

int main ()
{
    scanf("%d", &n);
    for(int i = 0; i < n; i ++ ) scanf("%d", &a[i]);
    
    int len = 0; // 存储当前的最大长度,也就是q里面的元素个数,最开始是0个,一个也没有
    
    q[0] = -2e9; //为了保证数组中小于某个数的数一定存在,把q[0]设置成无穷小,当成哨兵
    for(int i = 0; i < n; i ++ ) //枚举每个数
    {
        int l = 0, r = len;
        while(l < r) //二分出来小于a[i]的最大的数
        {
            int mid = l + r + 1 >> 1;
            if(q[mid] < a[i]) l = mid;
            else r = mid - 1;
        }
        len = max(len, r + 1); //更新
        q[r + 1] = a[i]; 
    }
    
    printf("%d\n", len);
    
    return 0;
}

这段代码使用了动态规划的思想,通过维护一个数组 q,其中 q[i] 表示长度为 i 的上升子序列的结尾的最小值。同时使用一个变量 len 记录当前的最大长度,初始化为 0。

然后,对于数组 a 中的每个元素 a[i],进行以下操作:

使用二分查找在 q 数组中找到小于 a[i] 的最大值的位置,设为 r。

如果找到的位置 r + 1 大于当前最大长度 len,则更新 len 为 r + 1。

将 q[r + 1] 更新为 a[i]。

最终,len 即为最长上升子序列的长度。

这种做法的关键在于通过二分查找,将每个元素 a[i] 放入合适的位置,以保证 q 数组中的元素是递增的,从而方便更新最大长度。通过动态维护 q 数组,避免了朴素动态规划中的多重循环,提高了算法的效率。


http://www.kler.cn/a/228836.html

相关文章:

  • ESP8266-01S、手机、STM32连接
  • 动手学大数据-3社区开源实践
  • 安全测评主要标准
  • 【网络协议】RFC3164-The BSD syslog Protocol
  • Spring Boot + Apache POI 实现 Excel 导出:BOM物料清单生成器(支持中文文件名、样式美化、数据合并)
  • 【RAG落地利器】向量数据库Qdrant使用教程
  • MySQL核心查询语句详解
  • Unity类银河恶魔城学习记录1-11 PlayerPrimaryAttack P38
  • RK3588开发板Ubuntu与开发板使用U盘互传
  • 【Linux】生产者消费者模型
  • 静态库和动态库
  • vue全屏,退出全屏、监听ESC退出全屏
  • 01背包问题 动态规划
  • CAN通信----(创芯科技)CAN分析仪----转CANTest使用
  • 2024年2月CCF-全国精英算法大赛题目
  • 前端面试题——Vue的双向绑定
  • <网络安全>《16 网络安全隔离与信息单向导入系统》
  • 计算机视觉实战项目3(图像分类+目标检测+目标跟踪+姿态识别+车道线识别+车牌识别+无人机检测+A*路径规划+单目测距与测速+行人车辆计数等)
  • 【HarmonyOS应用开发】Web组件的使用(十三)
  • 壹[1],Xamarin开发环境配置
  • linux的nginx安装
  • 复旦大学NLP团队发布86页大模型Agent综述
  • Git私服搭建
  • UML---用例图,类图
  • 前端如何预防CSRF
  • python的进程,线程、协程