字符串处理 相同的子串

// 共同子段
// 4、输出两个字符串中的最长公共子串。
// 例如:“abcfabcd”和“abcdabce”中最长公共子串为“abcd”。
public static void f4(){
String str1 = "abcfabcd";
String str2 = "arcfabdabce";
// 获取两个字符的所有字串的情况
//字符串1
ArrayList<String> list1 = new ArrayList<String>();
for(int i=0;i<str1.length();i++){
for(int j=1;j<str1.length()-i+1;j++){
list1.add(str1.substring(i, i+j));
}
}
//字符串2
ArrayList<String> list2 = new ArrayList<String>();
for(int i=0;i<str2.length();i++){
for(int j=1;j<str2.length()-i+1;j++){
list2.add(str2.substring(i, i+j));
}
}

// 得到了两个字符串的所有子串
// 在list1 中提取元素 , 看list2 中是否有相同的子串
ArrayList<String> sameStr = new ArrayList<String>();
for(int i=0;i<list2.size();i++){
if(list1.contains(list2.get(i))){ //有这个子串
// System.out.println("两个字符串中相同的子串味:"+list2.get(i));
sameStr.add(list2.get(i)); //保存两个字符串中相同的子串
}
}

// 找到最长的子段
String maxLength = null;
int maxIndex = sameStr.get(0).length();
for(int i=0;i<sameStr.size();i++){
if(maxIndex<sameStr.get(i).length()){
maxIndex = sameStr.get(i).length();
maxLength = sameStr.get(i);
}
}
System.out.println("两个字符串中最大长度相同子串为:"+maxLength);

//输出测试
// for(int i=0;i<list1.size();i++){
// System.out.println("str1的子串:"+list1.get(i));
// System.out.println("str2的子串:"+list2.get(i));
// }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值