给定一组非负整数 nums,重新排列每个数的顺序(每个数不可拆分)使之组成一个最大的整数。
注意:输出结果可能非常大,所以你需要返回一个字符串而不是整数。
示例 1:
输入:nums = [10,2]
输出:"210"
示例 2:
输入:nums = [3,30,34,5,9]
输出:"9534330"
【解题思路】A=321, B=325, BA>AB。A=34, B=245,AB>BA。要按照这样的规则比较大小,令ab>ba,sa为大于a的n个10相乘的数,sb为大于b的m个10相乘的数。则a*sb+b>b*sa+a。
class Solution {
public String largestNumber(int[] nums) {
Integer[] newNums = new Integer[nums.length];
for(int i = 0; i < nums.length; i++)
{
newNums[i] = nums[i];
}
Arrays.sort(newNums, (a, b)->{
int sa = 10;
int sb = 10;
while(sa <= a) sa *= 10;
while(sb <= b) sb *= 10;
return (int)(-a*sb-b+b*sa+a);
});
if(newNums[0] == 0) return "0";
StringBuilder str = new StringBuilder();
for(int num : newNums)
{
str.append(num);
}
return str.toString();
}
}