윤개발
백준 5582번 공통 부분 문자열 본문
문제
두 문자열이 주어졌을 때, 두 문자열에 모두 포함된 가장 긴 공통 부분 문자열을 찾는 프로그램을 작성하시오.
어떤 문자열 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