import java.util.ArrayList;
public class LCS {
public static void main(String[] args) {
char[] strArray1 = "blue@sina.com".toCharArray();
char[] strArray2 = "www.blue.com".toCharArray();
LCS lcs=new LCS();
ArrayList longestSubStr = lcs.getLongestSubStr(strArray1, strArray2);
if (longestSubStr.isEmpty()){
System.out.println("No common substring");
}else{
System.out.println("longest common substring:"+longestSubStr);
}
}
/* return all the longest substrings*/
public ArrayList getLongestSubStr(char[] s1, char[] s2) {
int lenS1 = s1.length;
int lenS2 = s2.length;
int c[][] = new int[lenS1][lenS2];//matrix
char[] result;
int start, len=0, i, j = 0;
ArrayList<Integer> endList=new ArrayList<Integer>();
for (i = 0; i < lenS1; i++) {
for (j = lenS2 - 1; j >= 0; j--) {
if (s1[i] == s2[j])
{
if (i == 0 || j == 0)// special case
c[i][j] = 1;
else {
c[i][j] = c[i - 1][j - 1] + 1;//set value for this position
}
} else
c[i][j] = 0;
if (c[i][j] > len) {
len = c[i][j];
endList.clear();
endList.add(j);
}else if (c[i][j] == len){
endList.add(j);//save the other substrings with the same length.
}
}
}
ArrayList resultList=new ArrayList();
for (int end : endList) {//loop for all the longest substrings
String strResult="";
start = end - len + 1;
for (i = start; i <= end; i++) {
strResult = strResult+ s2[i]+"";
}
resultList.add(strResult);
}
return resultList;
}
}
LCS.zip_Java LCS_lcs java
版权申诉
67 浏览量
2022-09-19
18:03:19
上传
评论
收藏 836B ZIP 举报
我虽横行却不霸道
- 粉丝: 72
- 资源: 1万+
最新资源
- 论文(最终)_20240430235101.pdf
- 基于python编写的Keras深度学习框架开发,利用卷积神经网络CNN,快速识别图片并进行分类
- 最全空间计量实证方法(空间杜宾模型和检验以及结果解释文档).txt
- 5uonly.apk
- 蓝桥杯Python组的历年真题
- 2023-04-06-项目笔记 - 第一百十九阶段 - 4.4.2.117全局变量的作用域-117 -2024.04.30
- 2023-04-06-项目笔记 - 第一百十九阶段 - 4.4.2.117全局变量的作用域-117 -2024.04.30
- 前端开发技术实验报告:内含4四实验&实验报告
- Highlight Plus v20.0.1
- 林周瑜-论文.docx
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈