JavaScript实现经典排序算法之插入排序


Posted in Javascript onDecember 28, 2016

插入排序的代码实现虽然没有冒泡排序和选择排序那么简单粗暴,但它的原理应该是最容易理解的了,因为只要打过扑克牌的人都应该能够秒懂。像排序一手扑克牌,开始时,我们的左手为空并且桌子上的牌面向下。然后,我们每次从桌子上拿走一张牌并将它插入左手中正确的位置。为了找到一张牌的正确位置,我们从右到左将它与已在手中的每张牌进行比较,拿在左手上的牌总是排序好的,原来这些牌是桌子上牌堆中顶部的牌。

1)算法原理

      插入排序(Insertion-Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。

2)算法描述和实现

     一般来说,插入排序都采用in-place在数组上实现。具体算法描述如下:

    <1> 从第一个元素开始,该元素可以认为已经被排序;

    <2> 取出下一个元素,在已经排序的元素序列中从后向前扫描;

    <3> 如果该元素(已排序)大于新元素,将该元素移到下一位置;

    <4> 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置;

    <5> 将新元素插入到该位置后;

    <6> 重复步骤2~5。

3)JavaScript代码实现

function insertSort(arr) { 
    for (var i = 1; i < arr.length; i++) { 
      var temp = arr[i]; 
      var j = i - 1; 
      while (j >= 0 && arr[j] > temp) { 
        arr[j + 1] = arr[j]; 
         j--; 
      } 
      arr[j + 1] = temp; 
    } 
    return arr; 
 } 
var arr = [1, 45, 37, 5, 48, 15, 37, 26, 29, 2, 46, 4, 17, 50, 52]; 
console.log(insertSort(arr));

        改进插入排序: 查找插入位置时使用二分查找的方式。

步骤:
        <1> 从第一个元素开始,该元素可以认为已经被排序;
        <2> 取出下一个元素,在已经排序的元素序列中二分查找到第一个比它大的数的位置;
        <3> 将新元素插入到该位置后;

function binaryInsertionSort(arr) { 
   for (var i = 1; i < arr.length; i++) { 
     var key = arr[i],left = 0,right = i - 1; 
     while (left <= right) { 
        var middle = parseInt((left + right) / 2); 
        if (key < arr[middle]) { 
          right = middle - 1; 
        } else { 
          left = middle + 1; 
        } 
     } 
     for (var j = i - 1; j >= left; j--) { 
        arr[j + 1] = arr[j]; 
     } 
     arr[left] = key; 
    } 
    return arr; 
} 
var arr = [1, 45, 37, 5, 48, 15, 37, 26, 29, 2, 46, 4, 17, 50, 52]; 
console.log(binaryInsertionSort(arr));

4)算法分析

      最佳情况:输入数组按升序排列。T(n) = O(n)
      最坏情况:输入数组按降序排列。T(n) = O(n2)
      平均情况:T(n) = O(n2)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 获取表单file全路径
Dec 31 Javascript
javascript数组去重小结
Mar 07 Javascript
每日十条JavaScript经验技巧(一)
Jun 23 Javascript
浅谈js和css内联外联注意事项
Jun 30 Javascript
js简单时间比较的方法
Aug 02 Javascript
Node.js 8 中的 util.promisify的详解
Jun 12 Javascript
angular学习之从零搭建一个angular4.0项目
Jul 10 Javascript
微信小程序分页加载的实例代码
Jul 11 Javascript
vue深入解析之render function code详解
Jul 18 Javascript
Vue使用json-server进行后端数据模拟功能
Apr 17 Javascript
layui 数据表格+分页+搜索+checkbox+缓存选中项数据的方法
Sep 21 Javascript
编写v-for循环的技巧汇总
Dec 01 Javascript
JavaScript实现经典排序算法之选择排序
Dec 28 #Javascript
详解js中常规日期格式处理、月历渲染和倒计时函数
Dec 28 #Javascript
JavaScript实现经典排序算法之冒泡排序
Dec 28 #Javascript
BootStrap Tooltip插件源码解析
Dec 27 #Javascript
获取当前月(季度/年)的最后一天(set相关操作及应用)
Dec 27 #Javascript
javascript实现文字无缝滚动
Dec 27 #Javascript
JavaScript仿聊天室聊天记录
Dec 27 #Javascript
You might like
PHP提示Notice: Undefined variable的解决办法
2012/11/24 PHP
thinkPHP使用post方式查询时分页失效的解决方法
2015/12/09 PHP
PHP批量去除BOM头内容信息代码
2016/03/11 PHP
php遍历替换目录下文件指定内容的方法
2016/11/10 PHP
利用php-cli和任务计划实现订单同步功能的方法
2017/05/03 PHP
ExtJS 2.0实用简明教程之应用ExtJS
2009/04/29 Javascript
js中生成map对象的方法
2014/01/09 Javascript
js格式化输入框内金额、银行卡号
2016/02/01 Javascript
Bootstrap Metronic完全响应式管理模板学习笔记
2016/07/08 Javascript
jQuery实现简单的回到顶部totop功能示例
2017/10/16 jQuery
vue移动端项目缓存问题实践记录
2018/10/29 Javascript
js prototype和__proto__的关系是什么
2019/08/23 Javascript
使用Layer组件弹出多个对话框(非嵌套)与关闭及刷新的例子
2019/09/25 Javascript
微信小程序 SOTER 生物认证DEMO 指纹识别功能
2019/12/13 Javascript
在Vuex中Mutations修改状态操作
2020/07/24 Javascript
JavaScript实现烟花绽放动画效果
2020/08/04 Javascript
解决vue单页面应用打包后相对路径、绝对路径相关问题
2020/08/14 Javascript
解决Element中el-date-picker组件不回填的情况
2020/11/07 Javascript
javascript实现点击小图显示大图
2020/11/29 Javascript
python线程锁(thread)学习示例
2013/12/04 Python
python3.3使用tkinter开发猜数字游戏示例
2014/03/14 Python
Python3实现Web网页图片下载
2016/01/28 Python
在Django model中设置多个字段联合唯一约束的实例
2019/07/17 Python
python实现网站用户名密码自动登录功能
2019/08/09 Python
pycharm 实现本地写代码,服务器运行的操作
2020/06/08 Python
Keras load_model 导入错误的解决方式
2020/06/09 Python
CSS3的Border-radius轻松制作圆角
2012/12/24 HTML / CSS
纯CSS实现设置半个字符的样式
2014/07/03 HTML / CSS
美国网上眼镜商城:Zenni Optical
2016/11/20 全球购物
美国专营婴幼儿用品的购物网站:buybuy BABY
2017/01/01 全球购物
中兴通讯全球官方网站:ZTE
2020/12/26 全球购物
一份婚庆公司创业计划书
2014/01/11 职场文书
社区学习十八大感想
2014/01/22 职场文书
学校标语大全
2014/06/19 职场文书
社区文艺活动方案
2014/08/19 职场文书
vue整合百度地图显示指定地点信息
2022/04/06 Vue.js