首页 > 编程语言 > 详细

Medium | LeetCode 179. 最大数 | 排序

时间:2021-02-02 11:16:48      阅读:27      评论:0      收藏:0      [点我收藏+]

179. 最大数

给定一组非负整数 nums,重新排列它们每个数字的顺序(每个数字不可拆分)使之组成一个最大的整数。

注意:输出结果可能非常大,所以你需要返回一个字符串而不是整数。

示例 1:

输入:nums = [10,2]
输出:"210"

示例 2:

输入:nums = [3,30,34,5,9]
输出:"9534330"

示例 3:

输入:nums = [1]
输出:"1"

示例 4:

输入:nums = [10]
输出:"10"

提示:

  • 1 <= nums.length <= 100
  • 0 <= nums[i] <= 109

解题思路

此题与 Medium | 剑指 Offer 45. 把数组排成最小的数 基本一致

public String largestNumber(int[] nums) {
    List<String> numString = new ArrayList<>(nums.length);
    for(int num : nums) {
        numString.add(String.valueOf(num));
    }
    numString.sort((str1, str2) -> (str2 + str1).compareTo(str1 + str2));
    StringBuilder sb = new StringBuilder();
    for (String nString : numString) {
        sb.append(nString);
    }
    if (sb.charAt(0) == ‘0‘) {
        return "0";
    }
    return sb.toString();
}

Medium | LeetCode 179. 最大数 | 排序

原文:https://www.cnblogs.com/chenrj97/p/14359894.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!