最大公共子串长度问题就是: 求两个串的所有子串中能够匹配上的最大长度是多少。 比如:“abcdkkk” 和 “baabcdadabc”, 可以找到的最长的公共子串是"abcd",所以最大公共子串长度为4。
『算法思路』
1、把两个字符串分别以行和列组成一个二维矩阵。
2、比较二维矩阵中每个点对应行列字符中否相等,相等的话值设置为1,否则设置为0。
3、通过查找出值为1的最长对角线就能找到最长公共子串。
针对于上面的两个字符串我们可以得到的二维矩阵如下:
从上图可以看到,str1和str2共有5个公共子串,但最长的公共子串长度为5。
为了进一步优化算法的效率,我们可以再计算某个二维矩阵的值的时候顺便计算出来当前最长的公共子串的长度,即某个二维矩阵元素的值由record[i][j]=1演变为record[i][j]=1 +record[i-1][j-1],这样就避免了后续查找对角线长度的操作了。修改后的二维矩阵如下:
『代码』
#include
#include
#include
#include
#include
using namespace std;
const int Max = 300;
int a[Max][Max] = {0};
int solve(string s1,string s2){
int maxx = -1;
int len1 = s1.length(),len2 = s2.length();
for(int i = 1; i <= len1; i++){
for(int j = 1; j <= len2; j++){
if(s1[i-1] == s2[j-1])
a[i][j] = a[i-1][j-1] +1;
maxx = max(maxx,a[i][j]);
}
}
return maxx;
}
int main(){
string s1,s2;
cin>>s1>>s2;
cout<<solve(s1,s2);
return 0;
}
思路来源:https://blog.csdn.net/qq_25800311/article/details/81607168
转自:大佬