Java 插入排序之二分法插入排序
- 二分法插入排序是直接插入排序的优化改进版(相对高效,也称为折半插入排序),在直接插入排序的基础上,用二分法查找替代线性顺序查找来确定插入位置,从而减少比较次数
- 二分法插入排序在性能上优于直接插入排序,适合小规模或部分有序的数据
- 时间复杂度:平均 O(n^2) 最好 O(log n) 最坏 O(n^2)
- 空间复杂度:O(1)
- 稳定性:稳定
public static void main(String[] args) {
int[] arr = {3, 5, 1, 7, 6, 2, 4};
for (int i = 1; i < arr.length; i++) {
int key = arr[i];
int left = 0;
int right = i - 1;
while (left <= right) {
int mid = left + (right - left) / 2;
if (arr[mid] < key) {
left = mid + 1;
} else {
right = mid - 1;
}
}
for (int j = i - 1; j >= left; j--) {
arr[j + 1] = arr[j];
}
arr[left] = key;
}
System.out.println("排序后的数组:");
for (int num : arr) {
System.out.print(num + " ");
}
}
排序后的数组:
1 2 3 4 5 6 7