Array.sort的使用方法
把数组排成最小的数
https://www.nowcoder.com/practice/8fecd3f8ba334add803bf2a06af1b993
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方法对字符串数组排序的核心代码和一些基本用法的示例。
查看11道真题和解析