leetcode-面试题45

面试题45. 把数组排成最小的数

输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。

示例 1:

输入: [10,2]
输出: "102"
示例 2:

输入: [3,30,34,5,9]
输出: "3033459"

提示:

0 < nums.length <= 100
说明:

输出结果可能非常大,所以你需要返回一个字符串而不是整数
拼接起来的数字可能会有前导 0,最后结果不需要去掉前导 0


//和leetCode-179一样
class Solution {
    public String minNumber(int[] nums) {
        if(nums == null || nums.length == 0)
            return "";
        String[] s_num = new String[nums.length];
        for(int i = 0; i < nums.length; i++){
            s_num[i] = String.valueOf(nums[i]);
        }
        Comparator<String> comp = new Comparator<String>(){
            @Override
            public int compare(String str1, String str2){
                String s1 = str1 + str2;
                String s2 = str2 + str1;
                return s1.compareTo(s2); 
            }
        };
        Arrays.sort(s_num, comp);
        // if(s_num[0].charAt(0) == '0')
        //     return "0";
        StringBuilder sb = new StringBuilder();
        for(String s: s_num)
            sb.append(s);
        return sb.toString();
    }
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1.把二元查找树转变成排序的双向链表 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。 要求不...
    曲终人散Li阅读 8,646评论 0 19
  • 说明: 本文中出现的所有算法题皆来自牛客网-剑指Offer在线编程题,在此只是作为转载和记录,用于本人学习使用,不...
    秋意思寒阅读 4,855评论 1 1
  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 8,949评论 0 2
  •   引用类型的值(对象)是引用类型的一个实例。   在 ECMAscript 中,引用类型是一种数据结构,用于将数...
    霜天晓阅读 4,804评论 0 1
  • 播种一种行为,收获一种习惯; 播种一种习惯,收获一种性格; 播种一种性格,收获一种命运。 行为变成了习惯,习惯养成...
    毙考题阅读 1,724评论 0 0

友情链接更多精彩内容