https://www.acmicpc.net/problem/12015
SOLUTION
최장 증가 부분 수열 (LIS : Longest Increasing Subsequence)문제이다.
흔치 않게 나무위키에서 제대로 자세하게 설명이 나와있기에 첨부한다.
간단하게 말하자면 먼저 답이될 수열을 dp = [] 로 정의한 뒤
for문으로 주어진 리스트 앞쪽부터 검사를 진행한다.
if: 현재 값이 수열에서 가장 크다면
--> dp의 가장 뒤에 값을 추가
else: 아니라면
--> 자신보다 큰 수 중 최솟값과 대치(이진탐색 이용)
이런식으로 진행하면 시간복잡도 O(nlogn)에 가장 긴 dp의 길이를 알아낼 수 있다.
그러나 만약 다음과 같은 수열이 주어지면
A = 3 5 7 9 2 1 4 8
우리가 예상하는 dp는 3 5 7 9 이지만
실제 dp는 1 4 7 8로 나온다.
따라서 해당 알고리즘은 정답 수열을 도출해내는 데에는 사용할 수 없다.
# 풀 수 없는 문제
가장 긴 증가장 긴 증가하는 부분 수열 4
https://www.acmicpc.net/problem/14002
가장 긴 증가장 긴 증가하는 부분 수열 5
https://www.acmicpc.net/problem/14003
PYTHON CODE
from bisect import bisect_left #이진탐색 코드, 같은 수일 경우 왼쪽 index를 돌려준다
input()
A = list(map(int, input().split()))
dp = []
for i in A:
k = bisect_left(dp, i) #자신이 들어갈 위치 k
if len(dp) <= k: #i가 가장 큰 숫자라면
dp.append(i)
else:
dp[k] = i #자신보다 큰 수 중 최솟값과 대체
print(len(dp))
'Programming [Python] > 백준 알고리즘 솔루션' 카테고리의 다른 글
#390 백준 파이썬 [1654] 랜선 자르기 - 이분탐색 (4) | 2020.02.02 |
---|---|
#389 백준 파이썬 [12738] 가장 긴 증가하는 부분 수열 3 - LIS (0) | 2020.02.01 |
#387 백준 파이썬 [1264] 모음의 개수 (0) | 2020.01.31 |
#385 백준 파이썬 [385] 돌 게임 2 (0) | 2020.01.31 |
#384 백준 파이썬 [9550] 아이들은 사탕을 좋아해 (0) | 2020.01.29 |