题目
给定两个字符串str1和str2,输出两个字符串的最长公共子串。
题目保证str1和str2的最长公共子串存在且唯一。
数据范围:1≤∣str1∣,∣str2∣≤5000
要求: 空间复杂度O(n2),时间复杂度O(n2)
示例1
输入:
"1AB2345CD","12345EF"
返回值:
"2345"
备注:1≤∣str1∣,∣str2∣≤5000
代码
import java.util.*;
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
* longest common substring
* @param str1 string字符串 the string
* @param str2 string字符串 the string
* @return string字符串
*/
public String LCS (String str1, String str2) {
//最长公共子串:连续,且前后顺序不能改变
//dp[i][j]表示到str1第i个,到str2第j个为止的公共子串长度
//1.创建dp表
//2.初始化
int[][] dp = new int[str1.length() + 1][str2.length() + 1];
int max = 0, pos = 0;
//3.填表
for(int i = 1; i <= str1.length(); i++) {
for(int j = 1; j <= str2.length(); j++) {
if(str1.charAt(i - 1) == str2.charAt(j - 1)) { //如果该两位相同
//则增加长度
dp[i][j] = dp[i - 1][j - 1] + 1;
} else { //如果该两位不相同
//该位置为0
dp[i][j] = 0;
}
//更新最大长度
if(dp[i][j] > max) {
max = dp[i][j];
pos = i - 1;
}
}
}
//4.返回值
//s.substring(indexStart,indexEnd) 表示截取字符串s的[indexStart,indexEnd)部分(左闭右开)
return str1.substring(pos - max + 1, pos + 1);
}
}