希尔排序
希尔排序的思想是分组的直接插入排序。由直接插入排序可知,若数据序列越接近有序,则时间效率越高;再者,当n越小时,时间效率越高。希尔排序就是基于这两点对直接插入排序进行改进的。
希尔排序算法描述如下:
1.将一个数据序列分成若干组,每组由若干相隔一段距离的元素组成,这段距离称为增量,在一个组内采用直接插入排序算法进行排序。
2.增量的初值通常为数据序列长度的一半,以后每趟增量逐渐缩小,最后为1.随着增量的逐渐减小,组数也减少,组内元素个数增加,整个序列接近有序。当增量为1时,只有一组,元素是整个序列,在进行一次直接插入排序即可。
package com.shellsort.yy;
/**
* 希尔排序,也叫做缩减增量排序,是插入排序的一种, 是针对直接插入排序的改进
*
* @author yuyang_csu
*@data 2013-4-5
*/
public class ShellSort {
private int[] arr;
public ShellSort(int[] arr) {
this.arr = arr;
}
public void shellSort(){
// 设置增量为数组长度的一半,并每次以1/2递减增量,直到以1为增量为止
for(int gap = arr.length/2;gap>0;gap/=2){
//将原数组拆分为i个小数组
for(int i = gap;i<arr.length;i++)
{
//待插入的元素
int tmp = arr[i];
//直接插入排序
for(int j =i;j>=gap&&tmp<arr[j-gap];j-=gap){
arr[j]=arr[j-gap];
arr[j-gap] = tmp;
}
}
}
}
//显示数组元素的方法
public void display(){
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
}
public static void main(String[] args) {
int[] arr = {1,9,2,10,3,11,4,12,5,13,6,14,7,15,8,16};
ShellSort ss = new ShellSort(arr);
ss.shellSort();
ss.display();
}
}
希尔排序的时间复杂度:查阅了好多资料,好像希尔排序的时间复杂度跟所给的序列有序程度有关,希尔排序的时间复杂度大概在O(NlogN)~~O(N^2)
希尔排序的稳定性:我们知道插入排序是稳定的,但在不同的插入排序过程中,相同的元素可能在各自的插入排序中移动,最后其稳定性就会被打乱,所以希尔排序是不稳定的。
分享到:
相关推荐
(1) 完成5种常用内部排序算法的演示,5种排序算法为:快速排序,直接插入排序,选择排序,堆排序,希尔排序; (2) 待排序元素为整数,排序序列存储在数据文件中,要求排序元素不少于30个; (3) 演示程序开始,...
一个数据结构作业,对刚刚学习希尔排序知识的同学有用,用C++做的
合并排序,插入排序,希尔排序,快速排序,冒泡排序,桶排序的C语言实现,原创。
希尔排序 希尔排序希尔排序希尔排序希尔排序希尔排序希尔排序希尔排序
实现以下常用的内部排序算法并进行性能比较:"直接插入排序"," 折半插入排序"," 2—路插入排序"," 表插入排序"," 希尔排序"," 起泡排序"," 快速排序"," 简单选择排序"," 树形选择排序"," 堆排序"," 归并排序"," 链式...
希尔排序的源代码; 平台:CentOS release 5.4 (Final) 编译器:GCC 4.3.2
用C++,模板写的 7中排序. 快速排序, 归并排序,插入排序,选择排序,起泡排序,堆排序,希尔排序
数据结构 综合排序 冒泡排序 直接插入排序 快速排序 希尔排序,完整的代码,有每种排序时间的比较
此希尔排序算法采用增量减半的方法来进行数据的排序,内有部分注释
排序算法: 1、插入排序 2、希尔排序 3、冒泡排序 4、快速排序 5、简单选择排序 6、堆排序
1) 至少采用三种方法实现上述问题求解(提示,可采用的方法有插入排序、希尔排序、起泡排序、快速排序、选择排序、堆排序、归并排序)。并把排序后的结果保存在不同的文件中。 2) 统计每一种排序方法的性能(以上机...
希尔排序法,最经典的排序法,但不是容易懂。包括希尔插入排序,希尔交换排序
排序算法很多,下面有基数排序,堆排序,希尔排序,直接插入排序的代码和思路
本实验含有四部分内容——直接插入排序、希尔排序、选择排序、快速排序,在上述内容的基础上,将所有排序算法整合在一个程序中。学生可参考教材中的伪代码。鼓励学生自创新思路,新算法。
就利用汇编版的希尔排序来写了一下超级列表框排序.发现,从取值-排序-显示过程才花了1秒的时间.速度是七号排序的30倍,凌晨孤星-超级列表框排序的3倍.而这个希尔排序模块.只用增加,删减自定义数据类型成员.即可变身另...
7大排序算法(快速排序,冒泡排序,选择排序,归并排序,插入排序,希尔排序,堆排序)实现源码
希尔排序,堆排序,快速排序,简单选择排序,插入排序,冒泡排序
插入排序之希尔排序
了解冒泡,选择,插入,希尔排序 基本的渐进分析
希尔排序(程序).txt希尔排序(程序).txt希尔排序(程序).txt