对于一个给定的字符串数组,请找到一种拼接顺序,使所有小字符串拼接成的大字符串是所有可能的拼接中字典序最小的。
给定一个字符串数组strs,同时给定它的大小,请返回拼接成的串。
测试样例:
["abc","de"],2
"abcde"
public class CombineString {
public static void main(String[] args) {
// TODO Auto-generated method stub
String[] strs={"ba","b"};
String[] strs2={"abc","ad","bc"};
System.out.println(findSmallest(strs,2));
System.out.println(findSmallest(strs2,3));
}
public static String findSmallest(String[] strs,int n){
if(strs==null||n==0)
return null;
Arrays.sort(strs, new strsComparator());
StringBuilder sb=new StringBuilder();
for(int i=0;i<n;i++){
sb.append(strs[i]);
}
return sb.toString();
}
public static class strsComparator implements Comparator<String>{
@Override
public int compare(String o1, String o2) {
//按字典顺序比较两个字符串,前者==后者,返回0;前者<后者,返回负数,否则,返回正数
return (o1+o2).compareTo(o2+o1);
}
}
}