最长公共子串(连续)

https://my.oschina.net/leejun2005/blog/117167

package com.imooc;

/**
* Project: girl
* Package: com.imooc
* Date: 2017/10/26 16:18
* Author: Simeon
*/
public class pp {
public static void getLCString(char[] str1, char[] str2) {
int i, j; //i看成横着的字符串 j看成竖着的字符串
int len1, len2;
len1 = str1.length;
len2 = str2.length;
int maxLen = len1 > len2 ? len1 : len2;
int[] max = new int[maxLen];
int[] maxIndex = new int[maxLen];
int[] c = new int[maxLen]; // 记录对角线上的相等值的个数

for (i = 0; i < len2; i++) {
for (j = len1 - 1; j >= 0; j--) {
if (str2[i] == str1[j]) { //当第二行开始的时候,判断有相同的找上次保存在C[]中的前一个数+1.
if ((i == 0) || (j == 0))
c[j] = 1;
else
c[j] = c[j - 1] + 1;
}
else { //如果不相同就把这一个位置的C[]设置为0;因此C[]的作用就是
c[j] = 0; //每次都存储矩阵上一行的值。
}

if (c[j] > max[0]) { // 如果是大于那暂时只有一个是最长的,而且要把后面的清0;
max[0] = c[j]; // 记录对角线元素的最大值,之后在遍历时用作提取子串的长度
maxIndex[0] = j; // 记录对角线元素最大值的!!列!!位置

for (int k = 1; k < maxLen; k++) {
max[k] = 0;
maxIndex[k] = 0;
}
}
else if (c[j] == max[0]) { // 有多个是相同长度的子串
for (int k = 1; k < maxLen; k++) {
if (max[k] == 0) { //往后扫描一个是0的位置,将第二个最大长度值插入。
max[k] = c[j];
maxIndex[k] = j;
break; // 在后面加一个就要退出循环了,找到位置就不用找了,跳出这个寻找循环。
}

}
}
}
}

for (j = 0; j < maxLen; j++) {
if (max[j] > 0) {
System.out.println("第" + (j + 1) + "个公共子串:");
for (i = maxIndex[j] - max[j] + 1; i <= maxIndex[j]; i++)
System.out.print(str1[i]);
System.out.println(" ");
}
}
}

public static void main(String[] args) {
String str1 = new String("1233456aaacd5677777777777777"); // max[3,3,3,0,0,0,……] 3表示长度 ,有三个相同长度的
String str2 = new String("233dddaaabc5678"); //maxIndex[3,9,14,0,0,……] 表示最长串结束位置,有三个最长,
// String str1 = new String("aab12345678cde");
// String str2 = new String("ab1234yb1234567");
getLCString(str1.toCharArray(), str2.toCharArray());
}
}

转载于:https://www.cnblogs.com/Simeonwu/p/7745387.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值