码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2015-02-02 07:05:20      阅读:229      评论:0      收藏:0      [点我收藏+]

标签:

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

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);
    }
}

 

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

标签:

原文地址:http://www.cnblogs.com/x113/p/4266708.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!