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

71、最长上升子序列II

最长上升子序列II

题目描述

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

输入格式

第一行包含整数N。

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

输出格式

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

数据范围

1 ≤ N ≤ 100000 , 1≤N≤100000, 1N100000
− 1 0 9 ≤ 数列中的数 ≤ 1 0 9 −10^9≤数列中的数≤10^9 109数列中的数109

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

Solution

import java.util.*;class Main{public static void main(String[] args){Scanner sc = new Scanner(System.in);int N = sc.nextInt();// N 为 100000, n 方的做法会 TLEint[] a = new int[N + 10];// res[i] 数组记录长度为 i 时,所有子序列中结尾最小的元素int[] q = new int[N + 10];// 初始化为 0int len = 0;for(int i = 1; i <= N; i++) {a[i] = sc.nextInt();// 二分查找优化时间复杂度 logn// 查找最后一个小于 a[i] 的值int idx = bsearch(q, len, a[i]);if(idx == len) {len++;q[len] = a[i];}else{if(q[idx + 1] > a[i]) q[idx + 1] = a[i];}}System.out.println(len);}public static int bsearch(int[] q, int n, int x){// 找最后一个小于 x 的位置// 如果都比 x 大的话返回 0// 从 1 到 n 开始二分int low = 1, high = n;while(low <= high){int mid = (low + high) / 2;if(q[mid] < x){if(mid == n || q[mid + 1] >= x) return mid;else low = mid + 1;}else high = mid - 1;}return 0;}
}
http://www.lryc.cn/news/373615.html

相关文章:

  • 解决必剪电脑版导出视频缺斤少两的办法
  • 新人学习笔记之(常量)
  • Lua解释器裁剪
  • web前端设计nav:深入探索导航栏设计的艺术与技术
  • 分析解读NCCL_SHM_Disable与NCCL_P2P_Disable
  • 使用 Python 进行测试(6)Fake it...
  • Flink Watermark详解
  • LeetCode538.把二叉搜索树转换为累加树
  • 关于编程思想
  • 521. 最长特殊序列 Ⅰ(Rust单百解法-脑筋急转弯)
  • 【YashanDB知识库】PHP使用OCI接口使用数据库绑定参数功能异常
  • 深入分析 Android BroadcastReceiver (三)
  • 在java中使用Reactor 项目中的一个类Mono,用于表示异步单值操作
  • LabVIEW故障预测
  • 掌握JavaScript中的`async`和`await`:循环中的使用指南
  • java第二十三课 —— 继承
  • 不可不知的Java SE技巧:如何使用for each循环遍历数组
  • 机器人建模、运动学与动力学仿真分析(importrobot,loadrobot,smimport)
  • 02-QWebEngineView的使用
  • 【2024亲测无坑】在Centos.7虚拟机上安装Oracle 19C
  • JS中判断一个字符串中出现次数最多的字符,统计这个次数?
  • rust-强化练习
  • TF-IDF算法
  • R语言数据分析案例29-基于ARIMA模型的武汉市房价趋势与预测研究
  • 面试-NLP八股文
  • 数据仓库之离线数仓
  • Mybatis源码解析
  • 前端学习CSS之神奇的块浮动
  • 【Java】内部类、枚举、泛型
  • LabVIEW电子类实验虚拟仿真系统