반응형
https://www.acmicpc.net/problem/12015
#include <iostream>
#include <vector>
using namespace std;
vector<int> arr, res;
int n, a;
int lowerBound(int target) {
int s = 0, e = res.size() - 1;
while (s < e) {
int mid = (s + e) / 2;
if (res[mid] >= target) e = mid;
else s = mid + 1;
}
return e;
}
int main() {
scanf("%d", &n);
for (int i = 0; i < n && scanf("%d", &a); i++) arr.push_back(a);
res.push_back(arr[0]);
for (int i = 1; i < n; i++) {
if (arr[i] <= res[res.size() - 1])
res[lowerBound(arr[i])] = arr[i];
else res.push_back(arr[i]);
}
printf("%d", res.size());
}
반응형
'Algorithm' 카테고리의 다른 글
백준 14003 : 가장 긴 증가하는 부분 수열 5 (0) | 2021.11.14 |
---|---|
백준 12738 : 가장 긴 증가하는 부분 수열 3 (0) | 2021.11.14 |
백준 2568 : 전깃줄 - 2 (0) | 2021.11.14 |
백준 2565 : 전깃줄 (0) | 2021.11.14 |
백준 1365 : 꼬인 전깃줄 (0) | 2021.11.14 |