实现一个排序方法,能对任意单一类型数组排序,比如intger0,String,Long0或者其他任意类型的数组代码不做限制可随意发挥
时间: 2024-02-05 14:11:35 浏览: 178
我可以给你提供一个通用的排序方法,使用 Java 语言实现。这个方法可以对任意类型的数组进行排序,只需要实现比较器接口 `Comparator<T>`,其中 `T` 是待排序数组的元素类型。
代码如下:
```java
import java.util.Arrays;
import java.util.Comparator;
public class Sorter {
/**
* 对任意类型的数组进行排序
*
* @param arr 待排序数组
* @param cmp 比较器
* @param <T> 数组元素类型
*/
public static <T> void sort(T[] arr, Comparator<T> cmp) {
Arrays.sort(arr, cmp);
}
public static void main(String[] args) {
// 示例:对字符串数组进行排序
String[] arr = {"hello", "world", "java", "algorithm", "data structure"};
sort(arr, (s1, s2) -> s1.compareTo(s2));
System.out.println(Arrays.toString(arr));
}
}
```
在上面的代码中,我们定义了一个静态方法 `sort`,它接受一个待排序的数组 `arr`,以及一个比较器 `cmp`。在 `sort` 方法内部,我们调用了 Java 标准库中的 `Arrays.sort` 方法,它可以对任意类型的数组进行排序。
比较器 `cmp` 是一个函数式接口,它有一个方法 `compare(T o1, T o2)`,用于比较两个对象 `o1` 和 `o2` 的大小。在 `main` 方法中,我们使用 lambda 表达式实现了一个字符串比较器,对字符串数组进行排序,并打印出排序后的结果。
你可以根据需要实现自己的比较器,来对不同类型的数组进行排序。
阅读全文