来源
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/largest-number/
描述
给定一组非负整数,重新排列它们的顺序使之组成一个最大的整数。
示例 1:
输入: [10,2]
输出: 210
示例 2:
输入: [3,30,34,5,9]
输出: 9534330
说明: 输出结果可能非常大,所以你需要返回一个字符串而不是整数。
题解
class Solution {private class LargerNumberComparator implements Comparator<String> {@Overridepublic int compare(String a, String b) {String order1 = a + b;String order2 = b + a;return order2.compareTo(order1);}}public String largestNumber(int[] nums) {String[] asStrs = new String[nums.length];for (int i = 0; i < nums.length; i++) {asStrs[i] = String.valueOf(nums[i]);}// Sort strings according to custom comparatorArrays.sort(asStrs, new LargerNumberComparator());// If, after being sorted, the largest number is `0`, the entire number// is zero.if (asStrs[0].equals("0")) {return "0";}String largestNumberStr = new String();for (String numAsStr : asStrs) {largestNumberStr += numAsStr;}return largestNumberStr;}}
复杂度分析
- 时间复杂度:
。尽管我们在比较函数中做了一些额外的工作,但是这只是一个常数因子。所以总的时间复杂度是由排序决定的。
- 空间复杂度:
