윤개발

백준 5582번 공통 부분 문자열 본문

알고리즘

백준 5582번 공통 부분 문자열

DEV_SJ 2020. 2. 25. 21:49

문제

두 문자열이 주어졌을 때, 두 문자열에 모두 포함된 가장 긴 공통 부분 문자열을 찾는 프로그램을 작성하시오.

어떤 문자열 s의 부분 문자열 t란, s에 t가 연속으로 나타나는 것을 말한다. 예를 들어, 문자열 ABRACADABRA의 부분 문자열은 ABRA, RAC, D, ACADABRA, ABRACADABRA, 빈 문자열 등이다. 하지만, ABRC, RAA, BA, K는 부분 문자열이 아니다.

두 문자열 ABRACADABRA와 ECADADABRBCRDARA의 공통 부분 문자열은 CA, CADA, ADABR, 빈 문자열 등이 있다. 이 중에서 가장 긴 공통 부분 문자열은 ADABR이며, 길이는 5이다. 또, 두 문자열이 UPWJCIRUCAXIIRGL와 SBQNYBSBZDFNEV인 경우에는 가장 긴 공통 부분 문자열은 빈 문자열이다.

입력

첫째 줄과 둘째 줄에 문자열이 주어진다. 문자열은 대문자로 구성되어 있으며, 길이는 1 이상 4000 이하이다.

출력

첫째 줄에 두 문자열에 모두 포함 된 부분 문자열 중 가장 긴 것의 길이를 출력한다.

 

풀이

다이나믹 프로그래밍으로 2차원 배열을 이용하여 풀이하였다. 

 

특정 문자열 i j 가 같을 경우에 그 직전 결과 +1 을 하면 된다.

 

예제

코드

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
 
public class P5582_공통_부분_문자열 {
 
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
 
        String s1 = br.readLine();
        String s2 = br.readLine();
 
        int dp[][] = new int[s1.length()][s2.length()];
 
        int max = 0;
 
        for (int i = 0; i < dp.length; i++) {
            for (int j = 0; j < dp[0].length; j++) {
                if (s1.charAt(i) == s2.charAt(j)) {
                    if (i != 0 && j != 0) {
                        dp[i][j] = dp[i - 1][j - 1+ 1;
                    } else {
                        dp[i][j] = 1;
                    }
                    max = Math.max(dp[i][j], max);
                }
            }
        }
 
        System.out.println(max);
 
    }
 
}
 
cs

'알고리즘' 카테고리의 다른 글

백준 2665 미로만들기  (0) 2020.02.29
백준 10819 차이를 최대로  (0) 2020.02.29
백준 9205번 맥주 마시면서 걸어가기  (0) 2020.02.24
백준 1181 단어정렬  (0) 2020.02.23
백준 1405번 - 미친로봇 (JAVA)  (0) 2019.09.21
Comments