`
Mr_Chunlei
  • 浏览: 28770 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

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

 
阅读更多

package com.hello;

import java.util.ArrayList;
import java.util.HashSet;
import java.util.Set;


/*
* @author 张春蕾 2013年10月8
*/
public class HelloJava{
	
	public static Set<String> getSet(String s1,String s2){
		ArrayList<String> arr1 = new ArrayList<String>();//用于存放字符串1所截取的所有字符串
		ArrayList<String> arr2 = new ArrayList<String>();//用于存放字符串2所截取的所有字符串
		Set<String> sets = new HashSet<String>();//用于存放两个字符串都含有的字符串
		if(s1 != null &&s2 !=null ){
			for(int i=0;i<s1.length();i++){//遍历循环字符串1,对字符串1所有的子字符串进行截取
				for(int j=i;j<s1.length();j++){
					arr1.add(s1.substring(i,j));
				}
			}
			
			for(int i=0;i<s2.length();i++){//遍历循环字符串2,对字符串2所有的子字符串进行截取
				for(int j=i;j<s2.length();j++){
					arr2.add(s2.substring(i, j));
				}
			}
			
			for(String s3 : arr1){//循环遍历找出两个字符串都含有的子串存入Set容器
				if(arr2.contains(s3)){
					sets.add(s3);
				}
			}
		}
		
		return sets;
	}
	
	public static void main(String[] args){
		String s1 = "abcdffffvvvvgssss";
		String s2 = "abcgffffvvddddssskkk";
		Set<String> set= getSet(s1,s2);
		String maxString = "";
		int maxLength = 0;
		for(String s3 : set){//循环遍历Set容器,找出最大的子字符串
			if(maxLength <=s3.length()){
				maxString = s3;
				maxLength = s3.length();
			}
		}
		System.out.print(maxString);
	}
}

输出结果为:ffffvv

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics