刷题刷出新高度,偷偷领先!偷偷领先!偷偷领先! 关注我们,悄悄成为最优秀的自己!
/**
* 希尔排序 针对有序序列在插入时采用移动法。
* <p/>
* 希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;
* 随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。
*
* @param sortArr
*/
private static void shellSort(int[] sortArr) {
//增量gap,并逐步缩小增量
for (int gap = sortArr.length / 2; gap > 0; gap /= 2) {
//从第gap个元素,逐个对其所在组进行直接插入排序操作
for (int i = gap; i < sortArr.length; i++) {
int j = i;
int temp = sortArr[j];
if (sortArr[j] < sortArr[j - gap]) {
while (j - gap >= 0 && temp < sortArr[j - gap]) {
//移动法
sortArr[j] = sortArr[j - gap];
j -= gap;
}
sortArr[j] = temp;
}
}
}
}
/**
* 希尔排序 针对有序序列在插入时采用交换法
*
* @param sortArr
*/
private static void shellSortSwap(int[] sortArr) {
//增量gap,并逐步缩小增量
for (int gap = sortArr.length / 2; gap > 0; gap /= 2) {
//从第gap个元素,逐个对其所在组进行直接插入排序操作
for (int i = gap; i < sortArr.length; i++) {
int j = i;
while (j - gap >= 0 && sortArr[j] < sortArr[j - gap]) {
//插入排序采用交换法
swap(sortArr, j, j - gap);
j -= gap;
}
}
}
}
/**
* 交换数组元素
*
* @param arr
* @param a
* @param b
*/
public static void swap(int[] arr, int a, int b) {
arr[a] = arr[a] + arr[b];
arr[b] = arr[a] - arr[b];
arr[a] = arr[a] - arr[b];
}
本文链接:Java版希尔排序
版权声明:本站点所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明文章出处。让学习像火箭一样快速,微信扫码,获取考试解析、体验刷题服务,开启你的学习加速器!
