7-3 希尔排序java
时间: 2023-12-21 22:31:31 浏览: 76
以下是一个在Java中实现希尔排序的示例代码:
```java
public class ShellSort {
public static void shellSort(int[] arr) {
int n = arr.length;
for (int gap = n / 2; gap > 0; gap /= 2) {
for (int i = gap; i < n; i++) {
int temp = arr[i];
int j;
for (j = i; j >= gap && arr[j - gap] > temp; j -= gap) {
arr[j] = arr[j - gap];
}
arr[j] = temp;
}
}
}
public static void main(String[] args) {
int[] arr = {7, 3, 5, 1, 9, 2};
shellSort(arr);
System.out.println("排序后的数组:");
for (int num : arr) {
System.out.print(num + " ");
}
}
}
```
这段代码实现了希尔排序算法。希尔排序是一种插入排序的改进版本,它通过将数组分成多个子序列来进行排序,然后逐步缩小子序列的间隔,直到间隔为1时完成最后一次排序。希尔排序的时间复杂度为O(nlogn)。
阅读全文