给定一个数组,元素都是正整数,要求返回这些元素所组成的最大数
e.g.: [7,8,86,4] 返回88674
<span style="font-size:18px;"> public String largestNumber(int[] num) {
if(num == null || num.length == 0)
return "";
String[] s_num = new String[num.length];
for(int i = 0; i < num.length; i++)
s_num[i] = String.valueOf(num[i]);
Comparator<String> comp = new Comparator<String>(){
@Override
public int compare(String str1, String str2){
String s1 = str1 + str2;
String s2 = str2 + str1;
return s2.compareTo(s1);
}
};
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();
}</span>