이 영역을 누르면 첫 페이지로 이동
Arc 블로그의 첫 페이지로 이동

Arc

페이지 맨 위로 올라가기

Arc

[Baekjoon] 11054: 가장 긴 바이토닉 부분 수열

  • 2022.10.19 03:49
  • Algorithm/PS
글 작성자: SeoArc

문제

 

풀이

내 풀이

import sys

n = int(sys.stdin.readline())
seq = list(map(int, sys.stdin.readline().split()))

dp = [1] * n
for i, v in enumerate(seq):
    for j in range(i-1, -1, -1):
        if seq[j] < v:
            dp[i] = max(dp[i], dp[j]+1)

for i, v in enumerate(seq):
    for j in range(i-1, -1, -1):
        if seq[j] > v:
            dp[i] = max(dp[i], dp[j]+1)

print(max(dp))

이 문제는 이전에 풀었던 11053번 가장 긴 증가하는 부분 수열 문제에서 변형된 문제이다.

아이디어는 11053번 문제와 비슷하다.

 

먼저 알아보기 쉽게 점들로 표현해보자

먼저 증가하는 수열을 체크해보자

순서를 매기기 위해 현위치에서 0쪽으로 선형탐색한다는 것을 생각하고 보면 이해가 수월하다.

그 다음 감소하는 수열을 체크해보자

감소하는 수열 역시 순서를 현위치에서 0쪽으로 선형탐색하여 찾아 매긴다는 것을 생각하여 살펴보자

이렇게 증가하는 수열의 길이를 메모해놓고 감소하는 수열을 체크하여 메모된 값에 누적시키면 최대 길이를 찾을 수 있게 된다.

항상 max 값을 찾으려 하기 때문에 감소하는 수열 체크 시 7번을 확인해도 max(6, 7)이므로 7이 최대길이로 나오게 된다.

 

회고

직관적으로 바로 풀긴했지만, 이렇게 해결된 이유를 좀 더 찾아서 설명할 수 있도록 분석해봐야 될 것 같다.

'Algorithm > PS' 카테고리의 다른 글

[Baekjoon] 1138: 한 줄로 서기  (0) 2023.02.26
[Baekjoon] 17298: 오큰수  (0) 2022.12.06
[Baekjoon] 3190: 뱀  (0) 2022.10.23
[Baekjoon] 1912: 연속합  (0) 2022.10.19
[Baekjoon] 11055: 가장 큰 증가 부분 수열  (0) 2022.10.13

댓글

이 글 공유하기

  • 구독하기

    구독하기

  • 카카오톡

    카카오톡

  • 라인

    라인

  • 트위터

    트위터

  • Facebook

    Facebook

  • 카카오스토리

    카카오스토리

  • 밴드

    밴드

  • 네이버 블로그

    네이버 블로그

  • Pocket

    Pocket

  • Evernote

    Evernote

다른 글

  • [Baekjoon] 17298: 오큰수

    [Baekjoon] 17298: 오큰수

    2022.12.06
  • [Baekjoon] 3190: 뱀

    [Baekjoon] 3190: 뱀

    2022.10.23
  • [Baekjoon] 1912: 연속합

    [Baekjoon] 1912: 연속합

    2022.10.19
  • [Baekjoon] 11055: 가장 큰 증가 부분 수열

    [Baekjoon] 11055: 가장 큰 증가 부분 수열

    2022.10.13
다른 글 더 둘러보기

정보

Arc 블로그의 첫 페이지로 이동

Arc

  • Arc의 첫 페이지로 이동

검색

메뉴

  • 홈
  • 태그
  • 방명록

카테고리

  • 분류 전체보기 (106)
    • Language (28)
      • C++ (0)
      • C# (0)
      • Java (28)
    • Algorithm (47)
      • Algorithm (15)
      • Data Structure (6)
      • PS (26)
    • Computer Science (22)
      • Design Pattern (1)
      • Network (14)
      • OS (7)
    • Game (0)
      • Unity (0)
    • Backend (3)
      • Spring (1)
      • JPA (2)
    • DB (0)
      • SQL (0)
    • DevOps (2)
      • AWS (0)
      • Docker (2)
      • Jenkins (0)
      • Nginx (0)
    • Software Engineering (4)
      • OOP (4)
    • AI (0)
      • Machine Learning (0)
    • Others (0)

최근 글

인기 글

댓글

공지사항

아카이브

태그

  • algorithm
  • java
  • 네트워크
  • 자바
  • 알고리즘
  • graph
  • network
  • 그래프

나의 외부 링크

정보

SeoArc의 Arc

Arc

SeoArc

블로그 구독하기

  • 구독하기
  • RSS 피드

방문자

  • 전체 방문자
  • 오늘
  • 어제

티스토리

  • 티스토리 홈
  • 이 블로그 관리하기
  • 글쓰기
Powered by Tistory / Kakao. © SeoArc. Designed by Fraccino.

티스토리툴바