import java.util.*; public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param numbers int整型一维数组 * @return string字符串 */ public String PrintMinNumber (int[] numbers) { // write code here if(numbers.length == 0) return ""; String[] nums = new String[numbers.length]; for(int i = 0; i < numbers.length; i++) nums[i] = "" + numbers[i]; Arrays.sort(nums, (s1, s2) -> (s1 + s2).compareTo(s2 + s1)); StringBuilder sb = new StringBuilder(); for(int i = 0; i < nums.length; i++) sb.append(nums[i]); return sb.toString(); } }
Arrays.sort
方法有两种重载形式:
- 对整个数组进行排序:
Arrays.sort(arr); //升序
- 对数组的一部分进行排序,指定起始和结束索引:
Arrays.sort(arr, fromIndex, toIndex);
如果你想对数组进行降序排序,可以使用Collections.reverseOrder()
配合Arrays.sort
:
Arrays.sort(arr, Collections.reverseOrder()); // 输出:[9, 8, 7, 5, 3, 1]
好的,这里是Arrays.sort
方法对字符串数组排序的核心代码,包括升序和降序排序:
// 假设有一个字符串数组strArr String[] strArr = {"Banana", "Apple", "Orange"}; // 对字符串数组进行升序排序 Arrays.sort(strArr); // 输出:[Apple, Banana, Orange] // 对字符串数组进行降序排序 Arrays.sort(strArr, Collections.reverseOrder()); // 输出:[Orange, Banana, Apple]
如果你想根据字符串的某个属性进行排序,比如按照字符串的长度,你可以提供一个自定义的比较器:
下面是使用Java语言编写的Arrays.sort
方法对字符串数组进行排序的核心代码,使用lambda表达式进行比较:
Arrays.sort(strArr, (s1, s2) -> s1.length() - s2.length()); // 根据字符串长度排序后的数组 // 输出:[Apple, Banana, Orange]
使用Java 8的lambda表达式简化Comparator的写法:
Arrays.sort(strArr, (s1, s2) -> Integer.compare(s1.length(), s2.length())); // 根据字符串长度排序后的数组 // 输出:[Apple, Banana, Orange]
如果你想按照自然顺序对字符串数组进行排序,但是数组中有null元素,你可以使用nullsFirst
或nullsLast
:
Arrays.sort(strArr, Collections.reverseOrder(nullsFirst(Comparator.naturalOrder()))); // 排序后的数组,null值会被放在数组的开头 // 输出:[null, Apple, Banana, Orange]
或者:
Arrays.sort(strArr, Collections.reverseOrder(nullsLast(Comparator.naturalOrder()))); // 排序后的数组,null值会被放在数组的末尾 // 输出:[Apple, Banana, Orange, null]
以上就是Arrays.sort
方法对字符串数组排序的核心代码和一些基本用法的示例。