效率:O(n*logN)

package sort;

import utils.Util;

/**
* 希尔排序
* 以h为间隔,进行比較。 按一定公式。先求出最大的间隔h
* 当h值大时,须要移动的元素个数就少,但移动的距离长。 内部以h步长的元素做插入排序
* 当h减小时。每趟排序须要移动的元素个数增多。但此时已接近于它们排序后的终于位置。这对于插入排序更有效率
*
* @author stone
* @date 2015-7-22 下午4:39:41
*/
public class ShellSort { public static void main(String[] args) { // int[] ary = Util.generateIntArray(10);
int[] ary = {7, 1, 3, 6, 4, 5, 2, 0};
Util.printArray(ary);
sort(ary);
Util.printArray(ary);
} static void sort(int[] ary) {
int h = 1;
while (ary.length/3 > h) {
h = 3 * h + 1;
}
while (h > 0) {
int j, temp;
for (int i = h; i < ary.length; i++) {
temp = ary[i];
// j = i;
// while (j > h - 1 && ary[j - h] >= temp) {
// ary[j] = ary[j - h];
// j -= h;
// }
for (j = i; j > h - 1 && ary[j - h] >= temp; j -= h) {
ary[j] = ary[j - h];
}
ary[j] = temp;
// System.out.println("移动---------");
// Util.printArray(ary);
}
h = (h - 1) / 3;
} }
/*
* [7, 1, 3, 6, 4, 5, 2, 0]
* h=4
* temp = ary[4], i = 4
* 1: [0] 比 [4] [0]>[4] [4]=[0] [0] = temp
* 2: temp=ary[5] [1] 比 [5] 不变
* 3: temp=ary[6] [2] 比 [6] 变化 [6]=[2] [2]=temp
* 4: temp=ary[7] [3] 比 [7] 变化 [7]=[3] [3]=temp
* 如今:
* [4, 1, 2, 0, 7, 5, 3, 6]
*
* [1, 4, 2, 0, 7, 5, 3, 6] 1 移位次数
* [1, 2, 4, 0, 7, 5, 3, 6] 1
* [0, 1, 2, 4, 7, 5, 3, 6] 3
* [0, 1, 2, 4, 7, 5, 3, 6]
* [0, 1, 2, 4, 5, 7, 3, 6] 1
* [0, 1, 2, 3, 4, 5, 7, 6] 3
* [0, 1, 2, 3, 4, 5, 6, 7] 1
*
* 以h为间隔, 按一定公式,先求出最大的间隔h
* while(h>0) {
* for(i=h;i<len;i++) {
* for(循环比較[h]和[i-h]的值,并移位)
* }
* h = 。。 。 最后一轮时 h=1. 这时 i=n i比(i-1),(i-1)再比((i-1)-1) 从后向前相邻两个相比
* }
*/
}

Java 希尔排序的更多相关文章

  1. java希尔排序

    java希尔排序 1.基本思想: 希尔排序也成为"缩小增量排序",其基本原理是,现将待排序的数组元素分成多个子序列,使得每个子序列的元素个数相对较少,然后对各个子序列分别进行直接插 ...

  2. Java希尔排序算法

    希尔排序就是对直接插入排序的一个优化.比如有这么一种情况:对一个无序数组进行从小到大的排序,但是数组的最后一个位置的数是最小的,我们要把它挪到第一个位置,其他位置的都要往后移动,要是这个数组非常大,那 ...

  3. Hark的数据结构与算法练习之希尔排序

    算法说明 希尔排序是插入排序的优化版. 插入排序的最坏时间复杂度是O(n2),但如果要排序的数组是一个几乎有序的数列,那么会降低有效的减低时间复杂度. 希尔排序的目的就是通过一个increment(增 ...

  4. 希尔排序(java)

    时间复杂度为O( n^(3/2) )不是一个稳定的排序算法 如何看一个算法是否稳定:{("scala",12),("python",34),("c++ ...

  5. 希尔排序及希尔排序java代码

    原文链接:http://www.orlion.ga/193/ 由上图可看到希尔排序先约定一个间隔(图中是4),然后对0.4.8这个三个位置的数据进行插入排序,然后向右移一位对位置1.5.9进行插入排序 ...

  6. Java实现希尔排序(增量递减排序)

    package Insert.sort; import java.util.Scanner; /*又叫缩小增量排序,本质是插入排序,将待排的序列增量分成几个子序列,分别对每个子序列进行直接插入排序 * ...

  7. Java实现希尔排序

            华杰让我看了一道面试题:现有一段程序S,可以对任意n个数进行排序.如果现在需要对n^2个数进行排序,最少需要调用S多少次?(只允许调用S,不可以做别的操作).         看到了这 ...

  8. 希尔排序java

    希尔排序简述 希尔排序是基于插入排序的以下两点性质而提出改进方法的: 插入排序在对几乎已经排好序的数据操作时,效率高,即可以达到线性排序的效率.(希尔排序先将部分数据进行排序,相当于已经部分排好序) ...

  9. 希尔排序----java实现

    思路:希尔排序是分组基础上的直接插入排序,给定的一个步长数组,每个小组先直接插入排序.虽然有四次循环,但是每次循环次数少. package com.sheepmu.text; import java. ...

随机推荐

  1. 深入理解ClassLoader工作机制(jdk1.8)

    ClassLoader 顾名思义就是类加载器,ClassLoader 作用: 负责将 Class 加载到 JVM 中    审查每个类由谁加载(父优先的等级加载机制)    将 Class 字节码重新 ...

  2. Material Designer的低版本兼容实现(三)——Color

    在Material Designer中,色彩再一次被摆到了重要的位置上.官方文档中竟然给出了500种配色方案进行选择.就是为了给不同的手机.电视.手表上带来一直的用户体验. 更多用于控制色彩的属性,可 ...

  3. 数据库分库分表中间件:Mycat;分布式数据库;mysql的分布式事务

    官网:http://mycat.io/,里面有电子书籍可以下载:http://www.mycat.io/document/mycat-definitive-guide.pdf 旧版本下载地址:http ...

  4. asp.net 判断用户是否使用微信浏览器

    平时我们看一些网页的时候会发现这样的功能:有的页面只能在微信里访问,如果在电脑上访问就提示用户请到微信上访问该网页.这个用C#怎么实现呢?我们结合代码来看看. 首先,我们需要先判断用户使用的是什么浏览 ...

  5. 请求被中止: 未能创建 SSL/TLS 安全通道,设置 TLSv1.2和TLSv1.1版本 .基础链接已经关闭,发送时发生错误

    WSO2 API访问的安全要求, 只能提供TLSv1.2和TLSv1.1版本,其它SSL版本协议因为存在较高安全漏洞问题会被disable. A 改成TLSv1.1或TLSv1.2,最好使用TLSv1 ...

  6. Mockito 中被 Mocked 的对象属性及方法的默认值

    在 Java 测试中使用 Mockito 有段时日了,以前只是想当然的认为 Mock 的对象属性值和方法返回值都是依据同样的规则.基本类型是 0, 0.0, 或 false, 对象类型都是 null, ...

  7. Word Ladder leetcode java

    题目: Given two words (start and end), and a dictionary, find the length of shortest transformation se ...

  8. 常见算法(logistic回归,随机森林,GBDT和xgboost)

    常见算法(logistic回归,随机森林,GBDT和xgboost) 9.25r早上面网易数据挖掘工程师岗位,第一次面数据挖掘的岗位,只想着能够去多准备一些,体验面这个岗位的感觉,虽然最好心有不甘告终 ...

  9. JAVA-SpringMVC基于注解模式第一个应用

    项目文件结构 1. web.xml配置文件 <?xml version="1.0" encoding="UTF-8"?> <web-app x ...

  10. Kafka:ZK+Kafka+Spark Streaming集群环境搭建(二十)ES6.2.2 Client API

    scala版本2.11 java版本1.8 spark版本2.2.1 es版本6.2.2 hadoop版本2.9.0 elasticsearch节点列表: 192.168.0.120 192.168. ...