尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

每日一题————2026-6-28 最长上升子序列加强版(线性DP版)

每日一题————2026-6-28 最长上升子序列加强版(线性DP版)
📅 发布时间:2026/6/29 18:17:42

最长上升子序列加强版

题目描述

给出一个由 n个不超过 10^9的正整数组成的序列。请输出这个序列的最长上升子序列的长度。

最长上升子序列是指,从原序列中按顺序取出一些数字排在一起,这些数字是逐渐增大的。

输入格式

第一行,一个整数 n,表示序列长度。

第二行有 n 个整数,表示这个序列。

输出格式

一个整数表示这个序列的最长上升子序列的长度。

输入输出样例

输入样例1:
7 3 1 2 5 4 9 7
输出样例1:
4

说明

对于20%的数据:n<=10

对于80%的数据:n<=5000

对于100%的数据:n<=1000000

对于嵌套循环超时的部分数据,可以采用二分优化:

【耗时限制】1000ms 【内存限制】512MB

参考AC代码:

#include <bits/stdc++.h>

using namespace std;

using LL = long long;
LL n, a, len, dp[1000010];

//可以用二分优化,下界
LL lower(LL l, LL r, LL x){
while (l < r){
LL mid = (l + r) >> 1;
if (dp[mid] >= x) r = mid;
else l = mid + 1;
}
return l;
}
int main(){
scanf ("%lld", &n);
for (LL i = 1;i <= n;i ++){
scanf ("%lld", &a);
if (len == 0 || dp[len] < a) dp[++ len] = a;
else dp[lower(1, len+ 1, a)] = a;
}
printf ("%lld", len);
return 0;
}

//要点:用二分进行优化,不然会超时

鼓励大家自己独立完成,不要直接抄哟~

相关新闻

  • 阿里云盘Refresh Token获取终极指南:3分钟扫码搞定自动化管理
  • TS泛型坑,编译懵!
  • 第11天:进程基础内核认知:PCB与task_struct结构体解析

最新新闻

  • 济南装修口碑哪家强?
  • 首页超出区域,预览的时候垂直溢出滚动,tabbar预览的时候在底部,即时设计实现
  • 中医舌象检测和识别2:基于深度学习YOLO26神经网络实现中医舌象检测和识别(含训练代码和数据集)
  • QKeyMapper:5分钟掌握Windows按键映射神器,游戏办公效率翻倍
  • QKeyMapper:5分钟解决你的Windows按键映射烦恼,手柄玩PC游戏不是梦!
  • 如何零代码打造个性化小米手表表盘:开源工具Mi-Create终极指南

日新闻

  • ENVI5.3.1实战:基于Landsat 8影像的区域无缝镶嵌与精准裁剪
  • 3步完成HS2-HF Patch安装:新手快速打造完美HoneySelect2体验
  • 微信好友检测终极指南:3分钟发现谁已悄悄删除你

周新闻

  • Windows字体自定义终极方案:No!! MeiryoUI完全指南
  • Deepin Boot Maker:告别命令行,3分钟制作Linux启动盘的智能解决方案
  • Plain Craft Launcher 2:重新定义你的Minecraft游戏体验

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号