题目信息
示例1:
示例2:
1 2
| 输入: [3,30,34,5,9] 输出: "3033459"
|
提示
1
| 1. 0 < nums.length <= 100
|
解题思路
本题难点
此题求拼接起来的 “最小数字” ,本质上是一个排序问题。
具体思路
字符串 xy < yx , yz < zy ,需证明 xz < zx 一定成立。
代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
| class Solution { public String minNumber(int[] nums) { String[] strs = new String[nums.length]; for(int i = 0; i < nums.length; i++){ strs[i] = String.valueOf(nums[i]); } quickSort(strs,0,strs.length - 1); StringBuilder res = new StringBuilder(); for(String s : strs){ res.append(s); } return res.toString(); }
public void quickSort(String[] strs,int l,int r){ if(l >= r){ return; } int i = l; int j = r; while(i < j){ while((strs[j] + strs[l]).compareTo(strs[l] + strs[j]) >= 0 && i < j){ j--; } while((strs[i] + strs[l]).compareTo(strs[l] + strs[i]) <= 0 && i < j){ i++; } swap(strs,i,j); } swap(strs,l,i); quickSort(strs,l,j-1); quickSort(strs,j+1,r); }
public void swap(String[] strs,int i ,int j){ String temp = strs[i]; strs[i] = strs[j]; strs[j] = temp; } }
|
复杂度分析:
- 时间复杂度 O(NlogN) :N 为最终返回值的字符数量( strs 列表的长度 ≤N );使用快排或内置函数的平均时间复杂度为 O(NlogN) ,最差为 O(N ^2 ) 。
- 空间复杂度 O(N) : 字符串列表 strs占用线性大小的额外空间。
其他优秀解答
解题思路
Java 内置数组排序函数: (x, y) -> (x + y).compareTo(y + x)
代码
1 2 3 4 5 6 7 8 9 10 11 12
| class Solution { public String minNumber(int[] nums) { String[] strs = new String[nums.length]; for(int i = 0; i < nums.length; i++) strs[i] = String.valueOf(nums[i]); Arrays.sort(strs, (x, y) -> (x + y).compareTo(y + x)); StringBuilder res = new StringBuilder(); for(String s : strs) res.append(s); return res.toString(); } }
|