最长公共子串

Posted zhangxiaoyu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了最长公共子串相关的知识,希望对你有一定的参考价值。

https://my.oschina.net/gaosheng/blog/308853

public static int LCS(char query[], char text[]) { int len_query = query.length; int len_text= text.length; //数组c记录匹配情况,模拟二维矩阵 int[] c = new int[len_text]; int len, i, j; len=0; for(i=0; i<len_query; i++) { //不反过来会把之前数组元素冲掉的,因为后面的元素需要根据前面的元素计算 for(j=len_text-1; j>=0; j--) { if(query[i] == text[j]) { if(i==0 || j==0) c[j]=1; else c[j]=c[j-1]+1; } else c[j] = 0; if(c[j] > len) len=c[j]; } System.out.println(Arrays.toString(c)); } return len; }

  

 

LCS(new char[]{‘a‘,‘b‘,‘c‘,‘d‘},new char[]{‘b‘,‘c‘,‘d‘});

[0, 0, 0]
[1, 0, 0]
[0, 2, 0]
[0, 0, 3]

 

以上是关于最长公共子串的主要内容,如果未能解决你的问题,请参考以下文章

最长公共子串与最长公共子序列

[程序员代码面试指南]递归和动态规划-最长公共子串问题

求两个字符串的最长公共子串,要求输入两个字符串,输出他们的最长公共子串,包括长度。

[程序员代码面试指南]递归和动态规划-最长公共子串问题(DP,LCST)

求字符串的最长公共子串

每日一题-——最长公共子序列(LCS)与最长公共子串