[백준] 9251 LCS

2024. 10. 9. 16:17·PS/백준
반응형

문제

https://www.acmicpc.net/problem/9251

입력

s1 = 문자열
s2 = 문자열

최대 1000글자

결과

ans: Int = 가장 긴 부분 수열의 길이

해석

LCS((Longest Common Subsequence))이므로 dp가 가장 먼저 생각난다.

 

점화식

dp[n][m] = s1의 n번째 s2[m]번째 문자까지 가장 긴 부분 수열의 길이

(if \ s[i] == s[j]),  (dp[i][j] = dp[i-1][j-1] +1 )  ,같은 문자를 찾으면 바로 직전 최장 부분 수열 + 1 
(else) (dp[i][j] = max(dp[i-1][j], dp[i][j-1]) ,같은 문자가 없을 경우 이전 경우의 수에서 가장 긴 것을 저장

 

S1 = ACAYKP, S2 = CAPCAK 일 경우 dp 배열은 다음과 같다.

 

  empty A C A Y K P
  0 0 0 0 0 0 0
C 0 0 1 1 1 1 1
A 0 1 1 2 2 2 2
P 0 1 1 2 2 2 3
C 0 1 2 2 2 2 3
A 0 1 2 3 3 3 3
K 0 1 2 3 3 4 4

 

여기서 중요한 점은 첫번째 행과 첫번 째 열을 0으로 초기화 시켜놓는 것이 중요하다 , 그래야 점화식을 세울 때
1부터 계산되어 편하게 사용할 수 있다. 

 

빨간색 부분은 같은 문자를 찾앗을 때 왼쪽 대각선 값 + 1 , 여기서 왼쪽 대각선인
i-1, j-1의 의미는 서로 한칸씩 전 상태를 의미한다.

 

그리고 빨간색이 아닌 부분은 바로 직전 상황, s1의 한칸 직전인 i-1 또는 s2의 한칸 직전인 j-1 중 더 큰 것을 선택

 

코드

import Foundation

var s1 = Array(readLine()!)
var s2 = Array(readLine()!)

let len = max(s1.count, s2.count)

var dp: [[Int]] = [[Int]](repeating: [Int](repeating: 0, count: len+1), count: len+1)

var ans: Int = 0

for i in 1...s1.count {
    for j in 1...s2.count {
        
        if s1[i-1] == s2[j-1] {
            dp[i][j] = dp[i-1][j-1] + 1
        } else {
            dp[i][j] = max(dp[i-1][j], dp[i][j-1])
        }
        
        ans = max(ans, dp[i][j])
    }
}

print(ans)

 

반응형

'PS > 백준' 카테고리의 다른 글

[백준] 15486 퇴사 2  (0) 2024.10.13
[백준] 11722 가장 긴 감소하는 부분 수열  (0) 2024.10.13
[백준] 1520 내리막 길  (1) 2024.10.11
[백준] 2294 동전 2  (2) 2024.10.10
[백준] 2293 동전 1  (0) 2024.10.09
'PS/백준' 카테고리의 다른 글
  • [백준] 11722 가장 긴 감소하는 부분 수열
  • [백준] 1520 내리막 길
  • [백준] 2294 동전 2
  • [백준] 2293 동전 1
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (304)
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (37)
        • swift (32)
        • python (4)
        • Kotlin (1)
      • iOS (132)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (32)
        • Framework (7)
        • Swift Concurrency (22)
        • Tuist (6)
        • Setting (11)
        • Modularization (1)
        • Instruments (6)
      • PS (59)
        • 프로그래머스 (24)
        • 백준 (13)
        • LeetCode (19)
        • 알고리즘 (3)
      • Git (18)
        • 명령어 (4)
        • 이론 (2)
        • hooks (1)
        • config (2)
        • action (7)
      • Shell Script (2)
      • Linux (6)
        • 명령어 (5)
      • Spring (13)
        • 어노테이션 (1)
        • 튜토리얼 (11)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    백준
    protocol
    프로그래머스
    dfs
    투포인터
    CS
    Spring
    concurrency
    UIKit
    Tuist
    lifecycle
    boostcamp
    IOS
    GIT
    SwiftUI
    property
    Swift
    AVFoundation
    dp
    dispatch
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[백준] 9251 LCS
상단으로

티스토리툴바