题目描述
blablabla
样例
#include <iostream>
#include <algorithm>
using namespace std;
const int N = 1e5+10;
int q[N], a[N], n;
int main(){
cin >> n;
for(int i = 0; i<n; i++){
cin >> a[i];
}
int len = 0;
q[0] = -2e9;
for(int i = 0; i<n; i++){
int l = 0, r = len;
while(l<r){
int mid = (l+r+1)>>1;
if(q[mid] < a[i]){
//第i个数,mid指代了多长的序列,
//q[mid] 指的是找长为mid序列的最后一个的最小值是比第i个数小的
l = mid;
}else {
r = mid-1;
}
}
len = max(len, r+1);//找到就意味着加上第i个可以再长1位,
q[r+1] = a[i];//同时更新再长1位的序列的最后一个的最小值;
}
cout << len << endl;
return 0;
}
算法1
(暴力枚举) $O(n^2)$
blablabla
时间复杂度
参考文献
C++ 代码
blablabla
算法2
(暴力枚举) $O(n^2)$
blablabla
时间复杂度
参考文献
C++ 代码
blablabla