算法回顾系列第五篇:希尔排序
---------------------------------------
希尔排序(缩小增量排序)
基本原理:
该方法实质上是一种分组插入排序方法,属于直接插入排序的改进算法。
比较相隔较远距离(称为增量)的数,使得数移动时能跨过多个元素,则进行一次比较就可能消除多个元素交换。
算法先将要排序的一组数按某个增量d分成若干组,每组中记录的下标相差d。
对每组中全部元素进行排序,然后再用一个较小的增量对它进行,在每组中再进行排序。
当增量减到1时,整个要排序的数被分成一组,排序完成。
(一般初次取序列一半为增量,然后每次减半,直到增量为1。)
程序实现:
public void sort(int[] data) {
//初次取序列长度一半为增量(相隔距离),以后每次减半,直到增量为1.
for(int i=data.length/2;i>2;i/=2){//i为增量,若大于2,则每次递减一半.
//每次增量缩小后都需要从头进行一次排序.
for(int j=0;j<i;j++){
insertSort(data,j,i);//起始为0,增量不为1的插入排序.
System.out.println("after insert sort:"+Arrays.toString(data));
}
System.out.println("sort:"+Arrays.toString(data));
}
insertSort(data,0,1);//起始为0,增量是1的直接插入排序.
System.out.println("after final sort:"+Arrays.toString(data));
}
/**
* 与直接插入排序实现类似,只不过增量不一定为1(不是相邻元素交换位置).
* @param data 待排序数组
* @param start 起始位置
* @param inc 增量
*/
private void insertSort(int[] data, int start, int inc){
int temp;
for(int i=start+inc;i<data.length;i+=inc){
for(int j=i;(j>=inc)&&(data[j]<data[j-inc]);j-=inc){
temp = data[j];
data[j] = data[j-inc];
data[j-inc] = temp;
//System.out.println("after swap:"+Arrays.toString(data));
}
}
}
public static void main(String[] args){
int[] data = new int[]{12,11,10,9,8,7,6,5,4,3,2,1};
new ShellSort().sort(data);
System.out.println(Arrays.toString(data));
}
上面程序中:
一共12个元素,增量分别为6,3,1.
第一次以6为增量分组,每组元素(相差距离为6)进行直接插入排序。
第二次以3为增量分组,每组元素(相差距离为3)进行直接插入排序。
最后以1为增量分组(即全部元素),进行一次直接插入排序。
性能分析:
平均时间复杂度 O(nlogn),最差时间复杂度O(n^2)。
空间复杂度:1。
稳定性:不稳定。
分享到:
相关推荐
希尔排序使用一个增量序列,逐步缩小间隔,使得元素可以更快地达到最终位置,从而提高了效率。 3. **冒泡排序**: 冒泡排序是一种简单的交换排序,通过不断比较相邻元素并交换位置,使得最大(或最小)的元素逐渐...
排序算法汇总P: 冒泡排序快速排序直接选择排序插入排序希尔排序 堆排序........
实现以下常用的内部排序算法并进行性能比较:"直接插入排序"," 折半插入排序"," 2—路插入排序"," 表插入排序"," 希尔排序"," 起泡排序"," 快速排序"," 简单选择排序"," 树形选择排序"," 堆排序"," 归并排序"," 链式...
本主题将详细探讨希尔排序、冒泡排序、堆排序等经典的排序算法,这些都是数据结构与算法学习中的核心内容,尤其对于北邮数据结构课程来说,理解并掌握这些排序方法至关重要。 1. **插入排序**: 插入排序是一种...
本文将详细探讨十种经典的排序算法在C++中的实现,分别是冒泡排序、桶排序、计数排序、堆排序、插入排序、合并排序、快速排序、基数排序、选择排序和希尔排序。 1. **冒泡排序**:冒泡排序是最简单的排序算法之一,...
以下是 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 ;...
5. 希尔排序:插入排序的优化版本,通过设置间隔序列来减少元素的移动次数。时间复杂度在最好情况下接近O(n),但最坏情况仍为O(n^2)。 6. 快速排序:采用分治策略,选取一个基准元素,将序列分为两部分,一部分小于...
希尔排序是基于插入排序的,但通过间隔序列(增量序列)来优化了插入排序的时间复杂度。 希尔排序的主要步骤如下: 1. **选择增量序列**:首先,我们需要一个增量序列{h1, h2, ..., hk},其中hi > hj 当 i ,k 是...
希尔排序,又称希尔斯排序,是由美国计算机科学家Donald Shell于1959年提出的一种改进的插入排序算法。它的主要思想是将待排序的数组元素按某个增量分组,然后对每组进行直接插入排序。随着增量逐渐减少,每组包含的...
常见算法八种常用的排序算法:插入排序、冒泡排序、选择排序、希尔排序、快速排序、归并排序、堆排序和LS_calgorithms
这七种算法分别是:冒泡排序、选择排序、直接插入排序、希尔排序、堆排序、归并排序和快速排序。 1. **冒泡排序**: 冒泡排序是最基础的排序算法之一,通过重复遍历待排序序列,比较相邻元素并交换位置来实现排序...
本文将深入探讨C#中常见的四种排序算法:冒泡排序、选择排序、插入排序和希尔排序,以及它们的实现细节和应用场合。 首先,我们来看**冒泡排序**。冒泡排序是一种简单的交换排序方法,它通过不断比较相邻元素并交换...
十大经典排序算法的实现:快速排序、堆排序、希尔排序、插入排序、冒泡排序、选择排序、归并排序、计数排序_SortAlgorithms
内容概要:希尔排序作为一种高效的改进型插入排序算法被详细介绍,主要内容涵盖希尔排序的基本概念,具体排序过程及其实现细节。文章还提供了希尔排序在不同编程语言环境(C++, C)中的实例代码实现,详细介绍了其执行...
十个基础排序算法:冒泡排序、选择排序、插入排序、希尔排序、归并排序、快速排序、堆排序、桶排序、计数排_SortAlgorithm
八种常用的排序算法:插入排序、冒泡排序、选择排序、希尔排序、快速排序、归并排序、堆排序和LST基数排_EightAlgorithms
希尔插入排序是希尔排序中最常见的实现方式之一,其基本步骤如下: - **初始化增量**:选择一个初始增量值(通常是数组长度的一半),然后不断减半直到增量为1。 - **分组排序**:根据当前增量值将数组分成若干组,...
本资源介绍了六种常用的排序算法:选择排序、直接插入排序、冒泡排序、希尔排序、快速排序和堆排序。下面对每种算法进行详细介绍: 选择排序 选择排序是一种简单的排序算法。其思想是:在要排序的一组数中,选出...
希尔排序(Shell Sort)是一种基于插入排序的快速排序算法,由Donald Shell于1959年提出。它的主要思想是将待排序的数据按照一个增量序列分成若干个子序列,然后分别对每个子序列进行插入排序,最后再进行一次全局的...
各种排序算法的实现函数:包括冒泡排序、选择排序、插入排序、希尔排序、归并排序、快速排序、堆排序、计数排序、桶排序、基数排序。 查找最大最小值函数 findMinMax:在给定数组中查找最大值和最小值。 计算平均值...