找出两个字符串中最长的相同子字符串

//找出两个字符串中最长的相同子字符串

public class Stringdemo {
    public static void main(String[] args) {
    
        String str1 = new String("eeabcde");
        String str2 = new String("bcdefabcabcdedegg");
        byte[] char1 = str1.getBytes();
        byte[] char2 = str2.getBytes();
        int len1 = char1.length;
        int len2 = char2.length;
        String maxchar=new String("");
        StringBuffer temp = new StringBuffer(" ");
        int maxl = 0;
        int loops = 0;
        for(int i=0;i<len1;i++)
            for(int j=0;j<len2;j++){
                int pos1 = i;
                int pos2 = j;
                int l = 0;
                //temp = new StringBuffer("");
                temp.delete(0, temp.length());
                while(char1[pos1]==char2[pos2]) {
                    l++;
                    temp.append((char)char1[pos1]);
                    if (++pos1>len1-1) break;
                    if (++pos2>len2-1) break;                    
                }
                //System.out.println(""+(++loops)+":"+temp);
                if (l>maxl) { 
                    maxl = l;
                    maxchar = temp.toString();
                    
                }
            }
        System.out.println(""+maxl+" "+maxchar);
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值