Interview100-68 排列数组为最小的数

题目

(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);
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值