https://www.acmicpc.net/problem/12015
12015번: 가장 긴 증가하는 부분 수열 2
첫째 줄에 수열 A의 크기 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄에는 수열 A를 이루고 있는 Ai가 주어진다. (1 ≤ Ai ≤ 1,000,000)
www.acmicpc.net
문제 설명:
수열 A가 주어졌을 때, 가장 긴 증가하는 부분 수열을 구하는 프로그램을 작성
예를 들어, 수열 A = {10, 20, 10, 30, 20, 50} 인 경우에 가장 긴 증가하는 부분 수열은 A = {10, 20, 10, 30, 20, 50} 이고, 길이는 4이다.
풀이설계
- 리스트에서 val을 하나씩 꺼내온다.
- dp[-1]는 보다 val이 크다면 뒤에 바로 추가해준다.
- 그렇지 않다면 이분탐색(bisect_left)을 이용하여 어디에 추가할지 인덱스를 정하고 val을 추가한다.
import sys
from bisect import bisect_left
input = sys.stdin.readline
n = int(input())
lst = list(map(int, input().split()))
dp = [0]
for val in lst:
if dp[-1] < val:
dp.append(val)
else:
dp[bisect_left(dp, val)] = val
print(len(dp)-1)
'코딩테스트 > 백준' 카테고리의 다른 글
[Python] 백준 2667번. 단지번호 붙이기 (0) | 2024.01.18 |
---|---|
[Python] 백준 15650번. N과 M(2) (0) | 2023.12.26 |
[Python] 백준 2108번. 통계학 (1) | 2023.12.19 |
[Python] 백준 11651번. 좌표 정렬하기 2 (0) | 2023.12.18 |
[Python] 백준 1932번. 정수 삼각형 (0) | 2023.12.11 |