JavaScript排序算法之希尔排序的2个实例


Posted in Javascript onApril 04, 2014

插入排序在对几乎已经排好序的数据操作时, 效率高, 即可以达到线性排序的效率。
但插入排序一般来说是低效的, 因为插入排序每次只能将数据移动一位。
希尔排序按其设计者希尔(Donald Shell)的名字命名,该算法由1959年公布。一些老版本教科书和参考手册把该算法命名为Shell-Metzner,即包含Marlene Metzner Norton的名字,但是根据Metzner本人的说法,“我没有为这种算法做任何事,我的名字不应该出现在算法的名字中。”

JavaScript排序算法之希尔排序的2个实例

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

该方法实质上是一种分组插入方法。

实例1:

/**
 * 希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。希尔排序是非稳定排序算法。
 *
 * 希尔排序是基于插入排序的以下两点性质而提出改进方法的:
 *
 * 插入排序在对几乎已经排好序的数据操作时, 效率高, 即可以达到线性排序的效率
 * 但插入排序一般来说是低效的, 因为插入排序每次只能将数据移动一位
 *
 */function shellSort( list ) {
    var gap = Math.floor( list.length / 2 );
    while( gap > 0 ) {
        for( i = gap; i < list.length; i++ ) {
            temp = list[i];
            for( j = i; j >= gap && list[j - gap] > temp; j -= gap ) {
                list[j] = list[j - gap];
            }
            list[j] = temp;
        }
        gap = Math.floor( gap / 2 );
    }
    return list;
};
// test
var arr = [2, 1, 3, 12, 5, 66, 23, 87, 15, 32];
shellSort(arr);

实例2:

<script type="text/javascript">
//document.write("----------希尔排序,插入排序的升级,1959年shell搞出来的------当增量取的正确时,时间复杂度为n的1.3次方-------");
//document.write("<br /><br />")
//var array = new Array(12, 25, 32, 16, 18, 27, 59, 69, 36);
function shellSort(array) {
 var j, i, v, h=1, s=3, k,n = array.length;
 var result = "";
 var count = 0;
    while(h < n)
  h=s*h+1; while(h > 1) {
  h=(h-1)/s;
       for (k=0; k<h; k++)
   for (i=k+h,j=i; i<n; i+=h, j=i) {
            v=array[i];
    while(true)
     if ((j-=h) >= 0 && array[j] > v)
      array[j+h]=array[j];
     else
      break;
    array[j+h]=v;
         }
   count++;
   result += "<br />第" + count + "遍排序的结果是:";
         for (var n = 0; n < array.length; n++) {
            result += array[n] + ",";
          }
 }
 return result;
}
//shallSort(array);
//document.write("<br /><br />");
</script>
Javascript 相关文章推荐
javascript之dhDataGrid Ver2.0.0代码
Jul 01 Javascript
node.js使用npm 安装插件时提示install Error: ENOENT报错的解决方法
Nov 20 Javascript
Jquery Mobile 自定义按钮图标
Nov 18 Javascript
Ext JS框架中日期函数的用法及日期选择控件的实现
May 21 Javascript
怎样判断jQuery当前元素是隐藏还是显示
Nov 23 Javascript
原生js实现手风琴功能(支持横纵向调用)
Jan 13 Javascript
详解JavaScript中的六种错误类型
Sep 21 Javascript
Angular @HostBinding()和@HostListener()用法
Mar 05 Javascript
原生js实现trigger方法示例代码
May 22 Javascript
原生JS利用transform实现banner的无限滚动示例代码
Jun 15 Javascript
JavaScript 闭包的使用场景
Sep 17 Javascript
在Vue中使用Select选择器拼接label的操作
Oct 22 Javascript
JavaScript中的prototype.bind()方法介绍
Apr 04 #Javascript
jQuery使用ajaxSubmit()提交表单示例
Apr 04 #Javascript
深入理解javascript的执行顺序
Apr 04 #Javascript
iframe窗口高度自适应的又一个巧妙实现思路
Apr 04 #Javascript
原生js获取宽高与jquery获取宽高的方法关系对比
Apr 04 #Javascript
在jquery中的ajax方法怎样通过JSONP进行远程调用
Apr 04 #Javascript
javascript中的循环语句for语句深入理解
Apr 04 #Javascript
You might like
PHP输出控制功能在简繁体转换中的应用
2006/10/09 PHP
PHP面向对象分析设计的61条军规小结
2010/07/17 PHP
给artDialog 5.02 增加ajax get功能详细介绍
2012/11/13 Javascript
使用GruntJS链接与压缩多个JavaScript文件过程详解
2013/08/02 Javascript
JS 实现BASE64_ENCODE和BASE64_DECODE(实例代码)
2013/11/13 Javascript
使用JS CSS去除IE链接虚线框的三种方法
2013/11/14 Javascript
浅析JavaScript中的隐式类型转换
2013/12/05 Javascript
jQuery实现鼠标划过修改样式的方法
2015/04/14 Javascript
Angularjs 事件指令详细整理
2017/07/27 Javascript
基于js原生和ajax的get和post方法以及jsonp的原生写法实例
2017/10/16 Javascript
分享vue.js devtools遇到一系列问题
2017/10/24 Javascript
微信小程序scroll-view组件实现滚动动画
2018/01/31 Javascript
如何在vue里面优雅的解决跨域(路由冲突问题)
2019/01/20 Javascript
微信小程序3种位置API的使用方法详解
2019/08/05 Javascript
使用VScode 插件debugger for chrome 调试react源码的方法
2019/09/13 Javascript
element-ui 实现响应式导航栏的示例代码
2020/05/08 Javascript
微信小程序:报错(in promise) MiniProgramError
2020/10/30 Javascript
利用Python批量生成任意尺寸的图片
2016/08/29 Python
详解python函数传参是传值还是传引用
2018/01/16 Python
python 除法保留两位小数点的方法
2018/07/16 Python
Python爬虫使用浏览器cookies:browsercookie过程解析
2019/10/22 Python
django 链接多个数据库 并使用原生sql实现
2020/03/28 Python
python matplotlib库的基本使用
2020/09/23 Python
CSS3属性使网站设计增强同时不消弱可用性
2009/08/29 HTML / CSS
你应该知道的30个css选择器
2014/03/19 HTML / CSS
彪马美国官网:PUMA美国
2017/03/09 全球购物
构造方法和其他方法的区别
2016/04/26 面试题
高三政治教学反思
2014/02/06 职场文书
喝酒检查书范文
2014/02/23 职场文书
党课培训心得体会
2014/09/02 职场文书
井冈山红色之旅感想
2014/10/07 职场文书
简易离婚协议书范本
2014/10/24 职场文书
美丽心灵观后感
2015/06/01 职场文书
晶体管单管来复再生式收音机
2021/04/22 无线电
PHP中strval()函数实例用法
2021/06/07 PHP
“鬼灭之刃”热度不减,其成功背后的原因是什么?
2022/03/22 日漫