题目描述
输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
解题思路
在这里自定义一个比较大小的函数,比较两个字符串s1, s2大小的时候,先将它们拼接起来,比较s1+s2,和s2+s1那个大,如果s1+s2大,那说明s2应该放前面,所以按这个规则,s2就应该排在s1前面。
代码示例
import java.util.Comparator;
import java.util.Arrays;
public class Solution {
public String PrintMinNumber(int [] numbers) {
if(numbers==null || numbers.length==0) return "";
int len = numbers.length;
String[] str = new String[len];
for(int i=0;i<len;i++){
str[i] = String.valueOf(numbers[i]);
}
Arrays.sort(str, new Comparator<String>(){
public int compare(String s1,String s2){
String c1= s1+s2;
String c2= s2+s1;
return c1.compareTo(c2);
}
});
StringBuilder sb=new StringBuilder();
for(int i=0;i<len;i++){
sb.append(str[i]);
}
return sb.toString();
}
}
总结
- 本题涉及到比较器:Comparator接口,两个对象要使用compareTo方法比较大小,就必须实现Comparator接口的compare方法,比如String就实现了这个方法,所以可以直接使用compareTo进行比较。sort(List,Comparator):根据指定的 Comparator 产生的顺序对 List 集合元素进行排序。
- String:不可变,线程安全
StringBuilder :可变,线程不安全
StringBuffer:可变,线程安全
网友评论