手机
当前位置:查字典教程网 >编程开发 >Java >希尔排序的算法代码
希尔排序的算法代码
摘要:希尔排序的时间复杂度为O(n*log2n)空间复杂度为O(1)是一种不稳定的排序算法思想:希尔排序也是一种插入排序方法,实际上是一种分组插入...

希尔排序的时间复杂度为O(n*log2n) 空间复杂度为O(1)是一种不稳定的排序算法

思想:希尔排序也是一种插入排序方法,实际上是一种分组插入方法。先取定一个小于n的整数d1作为第一个增量,把表的全部记录分成d1个组,所有距离为d1的倍数的记录放在同一个组中,在各组内进行直接插入排序;然后,取第二个增量d2(<d1),重复上述的分组和排序,直至所取的增量dt=1(dt<dt-1<…<d2<d1),即所有记录放在同一组中进行直接插入排序为止。

复制代码 代码如下:

void ShellSort(int* data ,int length)

{

if( data == NULL || length <= 0 )

return;

int d = length/2; //步长

while( d )

{

for(int i = 0 ; i < d ; ++i) //根据步长分成组,对每组进行插入排序

{

//插入排序

for(int j = i+d; j <length ; j +=d )

{

if( data[j] < data[j -d])

{

int temp = data[j]; //哨兵

int k = j-d;

for(; k >=0&& temp < data[k]; k -=d)

{

data[k+d] =data[k];

}

data[k+d] =temp;

}

}

}

d = d/2;

}

}

【希尔排序的算法代码】相关文章:

基于Java内存溢出的解决方法详解

Java 进制转换的方法

java大数乘法的简单实现 浮点数乘法运算

JAVA实现多线程的两种方法实例分享

Velocity基本语法介绍

Java多线程的用法详解

java冒泡排序算法代码

java中调用GDAL DLL的实现方法

java时间戳转日期格式的实现代码

Java程序执行时间的2种简单方法

精品推荐
分类导航