问题是根据字符串的长度对字符串数组进行排序。
例如
input = {"cat", "star", "act", "gid", "arts", "dog", "rats"}
output = {"cat", "act", "gid", "dog", "star", "arts", "rats"}
我使用插入排序(使用字符串的长度而不是字符串本身)来做到这一点。我的问题:有更好的方法吗?
我想到的另一种选择是 - 使用 aTreeMap
将每个字符串及其长度存储为值(假设字符串在给定数组中是唯一的)。然后根据其值对其进行排序。运行时间为O(nlogn)
,空间复杂度为O(n)
。您认为这是更好的方法吗?
编辑:很抱歉之前没有提到这一点 - 我想在不使用Arrays.sort()
或自定义比较器的情况下执行此操作。
插入排序的代码示例:
public static String[] insertionSort(String[] arr) {
for(int i=1;i<arr.length;i++) {
int j = 0;
for(;j<i;j++) {
if(arr[j].length() > arr[j+1].length()) {
String temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
return arr;
}