0
点赞
收藏
分享

微信扫一扫

HDU 1257 最小拦截系统——LIS


nlog的LIS

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>

using namespace std;

const int maxn = 1e5 + 10;

int n, ans, a[maxn], b[maxn];

int main() {
while (cin >> n) {
ans = 1;
for (int i = 1; i <= n; i++) {
cin >> a[i];
}
int cnt = 0;
b[++cnt] = a[1];
for (int i = 2; i <= n; i++) {
if (b[cnt] < a[i]) {
b[++cnt] = a[i];
}
else {
int pos = lower_bound(b + 1, b + 1 + cnt, a[i]) - b;
b[pos] = a[i];
}
}
cout << cnt << endl;
}
return 0;
}



举报

相关推荐

0 条评论