查找两个字符串的最大相同子串

转自: http://hi.baidu.com/defeat2001/blog/item/29f760258294c921d507421d.html

 

 

public class BigestCommonSubString {

    // 查找两个字符串的最大相同子串,最大交集
    public static void main(String[] args) {

        String str1 = "asdfdfdfdfdfdfdfdfdfasf34lk343434343433333fdasfd";
        String str2 = "asdfdfdfdfdfdfdfdfdf3434343434343jfshasdazlzlasbfasfdllzlz";
        String targetString = getSubString(str1, str2);
        System.out.println(targetString);
   }
    // 获得最大相同子串,这个方法可以被外部调用
    public static String getSubString(String str1, String str2) {
        String targetString = null;
        // 取出其中较短的字符串(照顾效率)
        String shorter = str1.length() > str2.length() ? str2 : str1;
        String longer = shorter.equals(str1) ? str2 : str1;


        // 在较短的字符串中抽取其‘所有长度’的子串,顺序由长到短
        out:
        for(int subLength = shorter.length(); subLength > 0; subLength--){
            // 子串的起始角标由 0 开始右移,直至子串尾部与母串的尾部-重合为止
            for(int i = 0; i+subLength <= shorter.length(); i++){
                String subString = shorter.substring(i, i+subLength); // 取子串
                if(longer.indexOf(subString) >= 0){ // 注意 ‘=’
                    targetString = subString;
                    break out; 
// 一旦满足条件,则最大子串即找到,停止循环,
                }
            }
        }
        return targetString;
   }
}
 


 

转自: http://www.blogjava.net/renyangok/archive/2007/03/05/101934.html

 

/**/ /* 
 求两个字符串的最大公共子串
 String s1 = "abcdefghigj";
 String s2 = "xyzabcdeigj";
 则输出abcde
 */  
 public   class  Test
  {
   public  String search(String s1,String s2)
    {
  String max  =   "" ;
   for ( int  i  =   0 ; i  <  s1.length(); i ++ )
    {
     for ( int  j  =  i + 1 ; j  <=  s1.length(); j ++ )
      {
      String sub  =  s1.substring(i,j);
       if ((s2.indexOf(sub) !=   - 1 ) &&  sub.length()  >  max.length())
        {
        max  =  sub;
      } 
    } 
  }   
   return  max;
  } 
  
   public   static   void  main(String[] args)
    {
    String s1  =   " abedafghigj " ;
    String s2  =   " xyzabfddfigj " ;
    String output  =   new  Test().search(s1,s2);
    System.out.println(output);
  } 
} 


 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值