输入一个非负整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。
示例 1: 输入: [10,2] 输出: “102”
示例 2: 输入: [3,30,34,5,9] 输出: “3033459”
通过在排序时传入一个自定义的 Comparator 实现,重新定义 String 列表内的排序方法,若拼接 s1 + s2 > s2 + s1,那么显然应该把 s2 在拼接时放在前面,以此类推,将整个 String 列表排序后再拼接起来。
class Solution { public String minNumber(int[] nums) { //将int类型的数组转化成String类型的数组 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 sb = new StringBuilder(); for(String s : strs){ sb.append(s); } return sb.toString(); } }或者
class Solution { public String minNumber(int[] nums) { List<String> strList = new ArrayList<>(); for (int num : nums) { strList.add(String.valueOf(num)); } strList.sort((s1, s2) -> (s1 + s2).compareTo(s2 + s1)); StringBuilder sb = new StringBuilder(); for (String str : strList) { sb.append(str); } return sb.toString(); } }至于lambda表达式,可以看之前总结的。