首页 > 编程语言 > 详细

排序---希尔排序Java

时间:2019-06-29 18:37:49      阅读:133      评论:0      收藏:0      [点我收藏+]

希尔排序

插入排序的一种又称“缩小增量排序”,是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。
希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。
    基本思想
先取一个小于n的整数d1作为第一个增量,把文件的全部记录分组。所有距离为d1的倍数的记录放在同一个组中。先在各组内进行直接插入排序;然后,取第二个增量d2<d1重复上述的分组和排序,直至所取的增量为1(选择增量d1=len/2,d2=d1/2...最后增量为1),即所有记录放在同一组中进行直接插入排序为止。
源代码:
技术分享图片 XierPaixu

 

功能要求:输入数组;输出每步骤的步长和排序情况;希望能进行排序方向的选择(从大到小或从小到大)

技术分享图片main

 

降序输出:

 

升序输出:

 

 

 

排序---希尔排序Java

原文:https://www.cnblogs.com/sengzhao666/p/11107275.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!