输入一个非负整数数组numbers,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。
例如输入数组[3,32,321],则打印出这三个数字能排成的最小数字为321323。
1.输出结果可能非常大,所以你需要返回一个字符串而不是整数
2.拼接起来的数字可能会有前导 0,最后结果不需要去掉前导 0
1、先将整型数组转化为字符串型数组
2、定义特定排序规则
3、用定义的排序规则对字符串型数组进行排序
4、将字符串型数组中每个元素拼接起来
5、得到最小的数
代码:
import java.util.ArrayList;
import java.util.Arrays;
public class Solution {
public String PrintMinNumber(int [] numbers) {
String[] st=new String[numbers.length];
for(int i=0;i((s1+s2).compareTo(s2+s1)));
StringBuilder sb=new StringBuilder();
for(String s:st){
sb.append(s);
}
return sb.toString();
}
}



