728x90
http://www.acmicpc.net/problem/11053
# 조건
- 수열 A가 주어졌을 때, 가장 긴 증가하는 부분 수열을 구하라
- A = {10, 20, 10, 30, 20, 50} 인 경우 가장 긴 증가하는 부분 수열은
- 10, 20, 30, 50 이고 길이는 4이다.
# 접근 방법
- dp를 이용해준다.
- 현재 인덱스의 숫자를 기준으로 이전의 숫자를 모두 훑어 준다.
- 1번부터 채워가기 때문에
- 비교하는 이전 dp 테이블의 값 +1 vs 현재 dp 테이블의 값을 비교해주면 된다.
- i=4 인 경우 j = 0 ~ 3까지의 값과 비교해주면 된다.
import sys
input = sys.stdin.readline
N = int(input())
arr = [*map(int, input().split())]
dp = [1 for _ in range(N)]
for i in range(N):
for j in range(i):
if arr[i] > arr[j]:
dp[i] = max(dp[i], dp[j]+1)
print(max(dp))
728x90
'ALGORITHM > DP(동적 계획법)' 카테고리의 다른 글
[백준 1149번] 파이썬 - RGB 거리 (0) | 2022.12.05 |
---|---|
[백준 12015번] 파이썬 - 가장 긴 증가하는 부분 수열2 (0) | 2022.11.10 |
[백준 2293번] 파이썬 - 동전 1 (0) | 2022.11.02 |
[프로그래머스] 파이썬 - 등굣길 (0) | 2022.10.19 |
[백준 2579번] 파이썬 - 계단 오르기 (0) | 2022.10.10 |