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方法有两种重载形式:

  1. 对整个数组进行排序:
Arrays.sort(arr);
//升序
  1. 对数组的一部分进行排序,指定起始和结束索引:
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元素,你可以使用nullsFirstnullsLast

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方法对字符串数组排序的核心代码和一些基本用法的示例。