题目
(2009.6 百度)把数组排列成最小的数。输入一个正整数的数组,将他们连接起来排成一个数,输出能够排出的所有数字中最小的一个。流入输入数组[32, 321],则输出这两个能排成的最小的数字为32132。请给出解决问题的算法,并证明该算法。
解法
1. 思路描述:(1)对于只有两个数的情况[3, 32],可以看出来332>323,因此需要交换3和32的顺序,然后直接拼接即为最小值。(2)对于有三个数的情况[3, 32, 321],需要进行两两拼接后比较,332>321,因此交换3和32的顺序,变成[32, 3, 321],然后比较3321>3213,继续交换顺序变成[32, 321, 3],比较32321>32132,继续交换得到[321, 32, 3]。然后按照最终的顺序拼接起来即为最小的元素
2. 由上面的分析可以看到,这里使用了一个规则(比较函数):str1+str2 > str2+str3时,有str1>str2。因此,可以构建一个自定义的比较函数,然后对数组中的数字转换为字符串进行拼接后比较排序,进而按照排序完成后的顺序拼接字符串即为最小的拼接数。
这里借助Java中对的自定义比较函数进行实现:
public class SmallestDigit {
public static String GetSmallestDigit(int[] array) {
Integer[] temp = new Integer[array.length];
for (int i = 0; i < array.length; i++) {
temp[i] = array[i];
}
Arrays.sort(temp, new Comparator<Integer>() {
@Override
public int compare(Integer num1, Integer num2) {
return (""+num1+num2).compareTo(""+num2+num1);
}
});
StringBuffer sb = new StringBuffer();
for (int i = 0; i < temp.length; i++) {
sb.append(temp[i]);
}
return sb.toString();
}
public static void main(String[] args) {
int[] array = {3, 32, 321};
String result = GetSmallestDigit(array);
System.out.println(result);
}
}