普通插入排序
时间复杂度O(n^2)
public void sort(int[] a) {
for (int i = 1; i < a.length; i++) {
int temp = a[i];
int j = i - 1;
for (j = i - 1; j >= 0; j--) {
if (a[j] >= temp) {
a[j + 1] = a[j];
} else {
break;
}
}
a[j + 1] = temp;
}
}
复制代码
折半插入排序
时间复杂度O(n*log(n))
public void sort(int[] a) {
for (int i = 1; i < a.length; i++) {
int temp = a[i];
int low = 0;
int high = i - 1;
while (low <= high) {
int mid = (low + high) >> 1;
if (a[mid] >= temp) {
high = mid - 1;
} else {
low = mid + 1;
}
}
for (int j = i - 1; j > high; j--) {
a[j + 1] = a[j];
}
a[high + 1] = temp;
}
}
复制代码
折半双插排序
public void sort(int[] a) {
for (int i = 1; i < a.length; i+=2) {
int temp;
int low;
int high;
if (i < a.length - 1) {
int max = a[i] > a[i+1]? a[i] : a[i+1];
int min = a[i] <= a[i+1]? a[i] : a[i+1];
low = 0;
high = i - 1;
while (low <= high) {
int mid = (low + high) >> 1;
if (a[mid] >= max) {
high = mid - 1;
} else {
low = mid + 1;
}
}
for (int j = i - 1; j > high; j--) {
a[j + 2] = a[j];
}
a[high + 2] = max;
temp = min;
low = 0;
}else {
temp = a[i];
low = 0;
high = i - 1;
}
while (low <= high) {
int mid = (low + high) >> 1;
if (a[mid] >= temp) {
high = mid - 1;
} else {
low = mid + 1;
}
}
for (int j = i - 1; j > high; j--) {
a[j + 1] = a[j];
}
a[high + 1] = temp;
}
复制代码
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END