算法回顾系列第五篇:希尔排序
---------------------------------------
希尔排序(缩小增量排序)
基本原理:
该方法实质上是一种分组插入排序方法,属于直接插入排序的改进算法。
比较相隔较远距离(称为增量)的数,使得数移动时能跨过多个元素,则进行一次比较就可能消除多个元素交换。
算法先将要排序的一组数按某个增量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. **冒泡排序**: 冒泡排序是一种简单的交换排序,通过不断比较相邻元素并交换位置,使得最大(或最小)的元素逐渐...
本文将深入探讨Java编程语言中实现的七种主要排序算法:直接插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序以及归并排序。每种算法都有其独特性,适用于不同的场景和数据特性。 1. **直接插入排序**:...
数据结构学习笔记排序算法:基数排序数据结构学习笔记排序算法:基数排序数据结构学习笔记排序算法:基数排序数据结构学习笔记排序算法:基数排序数据结构学习笔记排序算法:基数排序数据结构学习笔记排序算法:基数...
(1) 完成5种常用内部排序算法的演示,5种排序算法为:快速排序,直接插入排序,选择排序,堆排序,希尔排序; (2) 待排序元素为整数,排序序列存储在数据文件中,要求排序元素不少于30个; (3) 演示程序开始,...
例如,插入排序和选择排序适合小规模数据,冒泡排序简单但效率低,希尔排序对大规模数据有优势,归并排序稳定但需要额外空间,快速排序在大多数情况下高效。在编程实践中,根据具体需求选择合适的排序算法是非常重要...
4. 时间复杂度分析:希尔排序的时间复杂度并不像其他排序算法那样有明确的上界,因为它依赖于增量序列的选择。在最好的情况下,时间复杂度可达到O(n log n),但在最坏情况下,时间复杂度可能接近O(n^2)。尽管如此,...
以下是 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 ;...
10. **希尔排序**:希尔排序是对插入排序的改进,通过设置间隔序列来减少元素的移动次数。其时间复杂度取决于间隔序列的选择,一般认为是O(n^(3/2))。 在Vue.js中实现这些排序算法,可以帮助开发者更好地理解算法...
6. 希尔排序:是对插入排序的一种改进,通过设置一个增量序列,使得元素能够跨过一定距离进行比较和交换,从而减少局部有序性的影响,提高排序速度。 7. 堆排序:利用了二叉堆的数据结构,可以看作是完全二叉树的...
希尔排序是基于插入排序的,但通过间隔序列(增量序列)来优化了插入排序的时间复杂度。 希尔排序的主要步骤如下: 1. **选择增量序列**:首先,我们需要一个增量序列{h1, h2, ..., hk},其中hi > hj 当 i ,k 是...
常见算法八种常用的排序算法:插入排序、冒泡排序、选择排序、希尔排序、快速排序、归并排序、堆排序和LS_calgorithms
这七种算法分别是:冒泡排序、选择排序、直接插入排序、希尔排序、堆排序、归并排序和快速排序。 1. **冒泡排序**: 冒泡排序是最基础的排序算法之一,通过重复遍历待排序序列,比较相邻元素并交换位置来实现排序...
十大经典排序算法的实现:快速排序、堆排序、希尔排序、插入排序、冒泡排序、选择排序、归并排序、计数排序_SortAlgorithms
这里我们关注的是六种经典的排序算法:快速排序、选择排序、冒泡排序、希尔排序、插入排序以及懒人排序。这六种算法都是使用C语言实现的,因此对C编程有一定的基础要求。 1. **快速排序**:由英国计算机科学家C.A.R...
希尔排序(Shell Sort)是一种基于插入排序的快速排序方法,由Donald Shell于1959年提出。它的主要思想是将待排序的数据按照一定的间隔进行分组,然后对每组...对于学习和理解排序算法,希尔排序是不可或缺的一部分。
内容概要:希尔排序作为一种高效的改进型插入排序算法被详细介绍,主要内容涵盖希尔排序的基本概念,具体排序过程及其实现细节。文章还提供了希尔排序在不同编程语言环境(C++, C)中的实例代码实现,详细介绍了其执行...
十个基础排序算法:冒泡排序、选择排序、插入排序、希尔排序、归并排序、快速排序、堆排序、桶排序、计数排_SortAlgorithm
八种常用的排序算法:插入排序、冒泡排序、选择排序、希尔排序、快速排序、归并排序、堆排序和LST基数排_EightAlgorithms
java8中经典排序算法:插入排序、堆排序,选择排序、希尔排序,基数排序、冒泡排序、归并排序、快速排_Arithmetic
实验7: 内部排序算法比较.doc 实验7: 内部排序算法比较.doc 实验7: 内部排序算法比较.doc