java排序算法之希尔排序
希尔排序是冲破二次时间屏障的第一批算法之一。
它是通过比较相距一定间隔的元素来工作,各趟比较所用的距离随着算法的进行而减小,直到最后一趟(比较相邻元素)为止。因此希尔排序也叫缩减增量排序。
希尔排序使用一个序列h1,h2,h3...hk来排序。
具体的意思是
第一趟排序比较的是相隔为hk的元素,也就是比较a[i]与a[i+hk],保证a[i]<=a[i+hk]。
第二次比较的是相隔为hk-1的元素,也就是比较a[i]与a[i+hk-1],保证a[i]<=a[i+hk-1]。
直到最后比较的是相隔之间为h1的元素。.
因此这个序列也叫增量序列,这个排序算法也叫缩减增量排序。
只要h1等与1,任何增量序列都是可以的。(也就是最后一定是比较相邻之间的元素)
具体看一下java的算法实现:
package k; import java.util.Scanner;
/**
* 希尔排序
* @author TangZH
*
*/
public class ShellSort { public static void main(String[] args)
{
Scanner in=new Scanner(System.in);
String str[]=in.nextLine().split("\\s+"); int inter[]=new int[str.length]; for(int i=0;i<str.length;i++)
{
inter[i]=Integer.valueOf(str[i]);
} ShellSort(inter); outPut(inter);
} /**
* 希尔排序
* @param inter
*/
private static void ShellSort(int inter[])
{
for(int gap=inter.length/2;gap>0;gap/=2) //gap为hk
{
for(int i=gap;i<inter.length;i++)
{
int j=i;
int temp=inter[i];
for(;j>=gap && temp<inter[j-gap];j-=gap)
inter[j]=inter[j-gap];
inter[j]=temp;
}
}
} private static void outPut(int []inter)
{
for(int n:inter)
{
System.out.printf("%d ", n);
}
} }
实现希尔排序的方法是SellSort(int inter[]);
接下来好好分析一下该算法的每个步骤:
假如输入的是:12 6 24 7 4 16(此时gap=4,i=4,j=4,temp=inter[4]=7)
1、此时gap=4
那么第一次7与12比较,如果小于就互相交换。
i++,12与4比较,小于就互换,
i++, 4与6比较,小于就互换,
i++,16与24比较,小于就互换。
第一趟之后为: 7 4 16 6
2、
4 4 16 12 12 6 24
此时gap=2
那么第一次4与7比较,如果小于就互相交换。
4 7 12 12 6 24
i++,16与4比较,小于就互换,这里16大于4,不变
4 16 12 6 24
i++, 12与7比较,不变,12与4比较,不变
4 7 12 6 24
i++,12与16比较,小于,于是变成 4 4 7 <> 12 16 6 24,12与4比较,大于4,因此12放进16原来在的位置
4 12 16 24
同样道理比较相同颜色的元素,进行排序。
.
.
.
第二趟之后为: 4 4 6 12 7 16 12 24
.
.
.
直到gap=1
每一趟的排序结果为(输入为:12 4 6 24 7 12 4 16)
7 4 4 16 12 12 6 24
4 4 6 12 7 16 12 24
4 4 6 7 12 12 16 24
4 4 6 7 12 12 16 24
总而言之:
gap的值就是hk,元素之间的间隔,这道题中gap=4,2,1。最外层的循环是给出gap的值.(每次都除以二),然后在循环里面开始对相隔为gap的元素进行插入排序,直到最后一趟比较相邻之间的元素。
希尔排序的最坏运行时间为O(N^2).由于Shell算法中增加了一个辅助空间temp,因此算法的辅助空间为S(n)=O(1).Shell排序是不稳定的。
java排序算法之希尔排序的更多相关文章
- 【DS】排序算法之希尔排序(Shell Sort)
一.算法思想 希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本.希尔排序是非稳定排序算法.希尔排序是基于插入排序的以下两点性质而提出改进方法的:1)插入排序在对几乎已经排好序的数据操作 ...
- 数据结构与算法之PHP排序算法(希尔排序)
一.基本思想 希尔排序算法是希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本. 该方法的基本思想是:先将整个待排元素序列分割成若干个子序列(由相隔某个“增量”的元素组成的)分别进行直接 ...
- 算法相关——Java排序算法之希尔排序(五)
个子块,即{3,5},{1,0},{5,2},{9,4},{6,12},将每个子块进行插入排序(即第i位与第i+5位进行比较交换),初步排序结果为{3,0,2,4,6,5,1,5,9,12}.希尔排序 ...
- 我的Java开发学习之旅------>Java经典排序算法之希尔排序
一.希尔排序(Shell Sort) 希尔排序(Shell Sort)是一种插入排序算法,因D.L.Shell于1959年提出而得名. Shell排序又称作缩小增量排序. 二.希尔排序的基本思想 希尔 ...
- 【排序算法】希尔排序算法 Java实现
希尔排序算法是按其设计者希尔(Donald Shell)的名字命名,该算法由1959年公布,是插入排序的一种更高效的改进版本. 希尔排序是基于插入排序的以下两点性质而提出改进方法的: 插入排序在对几乎 ...
- Java学习笔记——排序算法之希尔排序(Shell Sort)
落日楼头,断鸿声里,江南游子.把吴钩看了,栏杆拍遍,无人会,登临意. --水龙吟·登建康赏心亭 希尔算法是希尔(D.L.Shell)于1959年提出的一种排序算法.是第一个时间复杂度突破O(n²)的算 ...
- 插入排序算法--直接插入算法,折半排序算法,希尔排序算法(C#实现)
插入排序算法主要分为:直接插入算法,折半排序算法(二分插入算法),希尔排序算法,后两种是直接插入算法的改良.因此直接插入算法是基础,这里先进行直接插入算法的分析与编码. 直接插入算法的排序思想:假设有 ...
- 排序算法之希尔排序的python实现
希尔排序(Shell’s Sort)是插入排序的一种,是直接插入排序算法的一种更高版本的改进版本. 希尔排序的工作原理 如下: (1)把记录按步长gap分组,对每组记录采用直接插入排序方法进行排序: ...
- js排序算法06——希尔排序
希尔排序本质是一种插入排序,由一位叫希尔的大神提出得名,其基本思想是将数组分组进行插入排序,每次消除不止一个逆序对,这样就提高了插入排序的效率.最后一步进行一间隔的插入排序,此时数组已经基本有序.代码 ...
随机推荐
- mac中:不能完成此操作,因为找不到一个或多个需要的项目。(错误代码 -43)
今天使用mac删除某文件时,遇到此错误: 不能完成此操作,因为找不到一个或多个需要的项目.(错误代码 -43) 于是采用命令行删除可以正确删除:在要删除的文件夹坐在目录下执行 rm -rf tes ...
- Redis 如何分析慢查询操作?
什么是慢查询 和mysql的慢SQL日志分析一样,redis也有类似的功能,来帮助定位一些慢查询操作. Redis slowlog是Redis用来记录查询执行时间的日志系统. 查询执行时间指的是不包括 ...
- java提高(7)---TreeSet--排序
TreeSet(一) 一.TreeSet定义: 与HashSet是基于HashMap实现一样,TreeSet同样是基于TreeMap实现的. 1)TreeSet类概述 ...
- ⑧javaWeb之在例子中学习(过滤器Filter)
前言 本系列 Servlet & JSP 学习系列[传送门]逐渐到了中期了,希望大家喜欢我写的,总结的点点滴滴- 今天我们来讲讲过滤器 你们的支持是我写博客的动力哦. 最近买了两本书,觉得大二 ...
- leetcode — minimum-path-sum
/** * Source : https://oj.leetcode.com/problems/minimum-path-sum/ * * * Given a m x n grid filled wi ...
- easyui datagrid列显示图片
表格头 显示图片 jquery
- 踏上编程大道 从 Python 开始成为神级 Coder
电脑科学,或说计算机科学,是个在美国不断成长的产业,薪资报酬也很高.市场上永远存在著对天赋异禀的新锐工程师的需求,这就是为什麽「学习程式语言」一直是一件有魅力的事情. 但是,就跟任何技能一样,我们常常 ...
- [总结] wqs二分学习笔记
论文 提出问题 在某些题目中,强制规定只能选 \(k\) 个物品,选多少个和怎么选都会影响收益,问最优答案. 算法思想 对于上述描述的题目,大部分都可以通过枚举选择物品的个数做到 \(O(nk^2)\ ...
- PXE+kickstart无人值守安装CentOS 7
kickstart+cobbler系列文章:http://www.cnblogs.com/f-ck-need-u/p/7048359.html 本文是PXE+kickstart无人值守安装CentOS ...
- javascript 小实例,求和的方法sumFn
新年第一记,从这里开始,先来个简单的!去年的知识梳理留下了很多尾巴,原因有很多(知识储量不足,懒了,项目多...) lg:都是借口~ 好吧,我承认,这都是借口,今年一定把尾巴清干净! 下面要写的是 ...