일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- function
- IMAGE
- 파이썬
- BAEKJOON
- 러스트
- 플랫폼
- 동시성
- Ethereum
- RabbitMQ
- guru
- docker
- Fast API
- rust
- AWS
- Container
- Thread
- fluent python
- Network
- 이더리움
- 백준
- Kubernetes
- Algorithm
- 블록체인
- 알고리즘
- dockerfile
- 코어 이더리움 프로그래밍
- 전문가를 위한 파이썬
- Python
- BlockChain
- Refactoring
Archives
- Today
- Total
글쓰기 | 방명록 | 관리 |
Victoree's Blog
12738_가장 긴 증가하는 부분 수열3 본문
728x90
Concept & Idea
LIS 알고리즘에 대해 공부하였다.
벡터는 lower_bound를 찾기 위한 벡터 배열이다.1. 해당하는 벡터 배열의 가장 마지막 요소보다 크기가 더 크면, 배열에 그냥 푸쉬해준다.2. 해당하는 벡터 배열의 가장 마지막 요소보다 크기가 더 작으면, 벡터 배열에 적절한 요소를 찾아 넣어준다.
이때 적절한 위치를 찾는데, 어차피 sort되어있는 배열이기 때문에 lower_bound를 이용하여 index를 찾고 값을 갱신해준다.
lower_bound를 사용할 때는, 해당 배열의 첫 주소, 끝 주소, 찾고싶은 값을 매개변수로 넣고 배열의 시작 주소를 빼주어야 index값을 구할 수 있다.
Code
#include <iostream>
#include <vector>
using namespace std;
int n;
long long map[1000001];
vector<long long> t;
int main() {
cin>>n;
for(int i=1; i<=n; i++)
cin>>map[i];
t.push_back(map[1]);
for(int i=2; i<=n; i++) {
if(map[i]>t[t.size()-1]) {
t.push_back(map[i]);
} else {
int lowIndex = lower_bound(t.begin(), t.end(), map[i])-t.begin();
t[lowIndex]=map[i];
}
}
cout<<t.size()<<endl;
}
Fealing
Lower_bound를 쓰는 법을 잘 공부하면 진짜 간단하고 짧게 구현할 수 있을 것 같다.
중요한 것은 내가 만든 벡터가 증가하는 부분 수열과 다르다는 점이다.
728x90
'Algorithm > 2019~2020' 카테고리의 다른 글
1660_캡틴 이다솜 (0) | 2021.04.22 |
---|---|
14003_가장 긴 증가하는 부분 수열5 (0) | 2021.04.22 |
1915_가장 큰 정사각형 (0) | 2021.04.22 |
2011_암호코드 (0) | 2021.04.22 |
9461_파도반 수열 (0) | 2021.04.22 |
Comments