最长公共子串的长度 描述:给定两个字符串str1和str2,输出两个字符串的最长公共子串的长度(假设str1和str2的最长公共子串存在且唯一)。 输入样例: 1AB2345CD 12345EF 输出样例: 4 说明:最长的公共子串为2345;java
时间: 2024-05-23 07:10:55 浏览: 169
可以使用动态规划来解决这个问题。
设 $dp[i][j]$ 表示以 $str1[i]$ 和 $str2[j]$ 结尾的最长公共子串的长度。当 $str1[i]$ 和 $str2[j]$ 相等时,$dp[i][j]$ 可以转移为 $dp[i-1][j-1]+1$,否则 $dp[i][j]$ 为 0。最后取所有 $dp[i][j]$ 中的最大值即为最长公共子串的长度。
具体实现时,可以用一个变量 $maxLen$ 来记录最大值,每次更新 $dp[i][j]$ 时,如果 $dp[i][j]>maxLen$ 则更新 $maxLen$。
Java 代码如下:
相关问题
最长公共子串的长度 描述:给定两个字符串str1和str2,输出两个字符串的最长公共子串的长度(假设str1和str2的最长公共子串存在且唯一)。
可以使用动态规划来解决这个问题。定义一个二维数组dp,其中dp[i][j]表示以str1[i-1]和str2[j-1]为结尾的最长公共子串的长度。则有以下状态转移方程:
dp[i][j] = 0 (如果i=0或j=0)
dp[i][j] = dp[i-1][j-1] + 1 (如果str1[i-1] = str2[j-1])
dp[i][j] = 0 (如果str1[i-1] != str2[j-1])
最终,最长公共子串的长度即为dp数组中的最大值。具体实现如下:
```
int longestCommonSubstring(string str1, string str2) {
int m = str1.length(), n = str2.length();
vector<vector<int>> dp(m+1, vector<int>(n+1, 0));
int ans = 0;
for (int i = 1; i <= m; i++) {
for (int j = 1; j <= n; j++) {
if (str1[i-1] == str2[j-1]) {
dp[i][j] = dp[i-1][j-1] + 1;
ans = max(ans, dp[i][j]);
} else {
dp[i][j] = 0;
}
}
}
return ans;
}
```
用java实现:最长公共子串的长度 描述:给定两个字符串str1和str2,输出两个字符串的最长公共子串的长度(假设str1和str2的最长公共子串存在且唯一)。
以下是用Java实现最长公共子串长度的示例代码:
```java
public class LongestCommonSubstring {
public static int longestCommonSubstring(String str1, String str2) {
int m = str1.length();
int n = str2.length();
int maxLength = 0;
int[][] dp = new int[m+1][n+1];
for (int i = 1; i <= m; i++) {
for (int j = 1; j <= n; j++) {
if (str1.charAt(i-1) == str2.charAt(j-1)) {
dp[i][j] = dp[i-1][j-1] + 1;
maxLength = Math.max(maxLength, dp[i][j]);
}
}
}
return maxLength;
}
public static void main(String[] args) {
String str1 = "abcdxyz";
String str2 = "xyzabcd";
int maxLength = longestCommonSubstring(str1, str2);
System.out.println("The length of longest common substring is " + maxLength);
}
}
```
以上代码使用动态规划算法来解决该问题。通过定义一个二维数组`dp`,其中`dp[i][j]`表示以`str1`的第`i`个字符和`str2`的第`j`个字符为结尾的最长公共子串的长度。当`str1.charAt(i-1) == str2.charAt(j-1)`时,表示`str1`和`str2`的第`i`和`j`个字符相同,因此可以通过`dp[i-1][j-1]`得到以`str1`的第`i-1`个字符和`str2`的第`j-1`个字符为结尾的最长公共子串长度,并加上当前相同的字符,即可得到以`str1`的第`i`个字符和`str2`的第`j`个字符为结尾的最长公共子串的长度。同时,需要记录每次更新的最大长度,并在遍历完成后返回该长度。
阅读全文