javascript基本常用排序算法解析


Posted in Javascript onSeptember 27, 2017

备注:内容大部分从网上复制,代码为自己手写。仅做知识的温故知新,并非原创。

1.冒泡排序(Bubble Sort)

(1)算法描述

冒泡排序是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。

(2)算法描述和实现

具体算法描述如下:

<1>.比较相邻的元素。如果第一个比第二个大,就交换它们两个;<2>.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对,这样在最后的元素应该会是最大的数;<3>.针对所有的元素重复以上的步骤,除了最后一个;<4>.重复步骤1~3,直到排序完成。

JavaScript代码实现:

javascript基本常用排序算法解析

改进冒泡排序:设置一标志性变量pos,用于记录每趟排序中最后一次进行交换的位置。由于pos位置之后的记录均已交换到位,故在进行下一趟排序时只要扫描到pos位置即可。

改进后算法如下:

javascript基本常用排序算法解析

传统冒泡排序中每一趟排序操作只能找到一个最大值或最小值,我们考虑利用在每趟排序中进行正向和反向两遍冒泡的方法一次可以得到两个最终值(最大者和最小者) , 从而使排序趟数几乎减少了一半。

改进后的算法为:

javascript基本常用排序算法解析

三种算法的运行时间为:

javascript基本常用排序算法解析

由运行结果可以看出时间复杂度更低,耗时更短了。大家可以亲自尝试下,运行的时候最好将三种算法写在一个文件中运行,否则会由于浏览器等原因产生误差。

冒泡排序的动态图演示:

javascript基本常用排序算法解析

(3)算法分析

最佳情况:T(n) = O(n)

当输入的数据已经是正序时

最坏情况:T(n) = O(n2)

当输入的数据是反序时

平均情况:T(n) = O(n2)

2.选择排序(Selection Sort)

表现最稳定的排序算法之一,因为无论什么数据进去都是O(n²)的时间复杂度…..所以用到它的时候,数据规模越小越好。唯一的好处可能就是不占用额外的内存空间了吧。理论上讲,选择排序可能也是平时排序一般人想到的最多的排序方法了吧。

(1)算法简介

选择排序(Selection-sort)是一种简单直观的排序算法。它的工作原理:首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。

(2)算法描述和实现

n个记录的直接选择排序可经过n-1趟直接选择排序得到有序结果。具体算法描述如下:

<1>.初始状态:无序区为R[1..n],有序区为空;<2>.第i趟排序(i=1,2,3…n-1)开始时,当前有序区和无序区分别为R[1..i-1]和R(i..n)。该趟排序从当前无序区中-选出关键字最小的记录 R[k],将它与无序区的第1个记录R交换,使R[1..i]和R[i+1..n)分别变为记录个数增加1个的新有序区和记录个数减少1个的新无序区;<3>.n-1趟结束,数组有序化了。

Javascript代码实现:

javascript基本常用排序算法解析

javascript基本常用排序算法解析

(3)算法分析

最佳情况:T(n) = O(n2)最差情况:T(n) = O(n2)平均情况:T(n) = O(n2)

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

Javascript 相关文章推荐
javascript EXCEL 操作类代码
Jul 30 Javascript
JS网页播放声音实现代码兼容各种浏览器
Sep 22 Javascript
javascript页面渲染速度测试脚本分享
Apr 15 Javascript
Javascript学习笔记之函数篇(五) : 构造函数
Nov 23 Javascript
解决node-webkit 不支持html5播放mp4视频的方法
Mar 11 Javascript
多种js图片预加载实现方式分享
Feb 19 Javascript
Javascript中字符串replace方法的第二个参数探究
Dec 05 Javascript
详解angularJs中自定义directive的数据交互
Jan 13 Javascript
JS排序算法之冒泡排序,选择排序与插入排序实例分析
Dec 13 Javascript
小程序清理本地缓存的方法
Aug 17 Javascript
vue + typescript + 极验登录验证的实现方法
Jun 27 Javascript
Electron+vue从零开始打造一个本地播放器的方法示例
Oct 27 Javascript
Angularjs cookie 操作实例详解
Sep 27 #Javascript
js移动端图片压缩上传功能
Aug 18 #Javascript
微信小程序报错:this.setData is not a function的解决办法
Sep 27 #Javascript
EasyUI Tree树组件无限循环的解决方法
Sep 27 #Javascript
详解微信小程序Page中data数据操作和函数调用
Sep 27 #Javascript
深入理解Vue生命周期、手动挂载及挂载子组件
Sep 27 #Javascript
微信小程序中button组件的边框设置的实例详解
Sep 27 #Javascript
You might like
php+ajax导入大数据时产生的问题处理
2014/06/11 PHP
php实现将数组转换为XML的方法
2015/03/09 PHP
PHP随机生成唯一HASH值自定义函数
2015/04/20 PHP
PHP实现在线阅读PDF文件的方法
2015/06/17 PHP
基于jquery打造的百分比动态色彩条插件
2012/09/19 Javascript
js字符串转成JSON
2013/11/07 Javascript
jQuery验证插件validation使用指南
2015/04/21 Javascript
JavaScript ES6的新特性使用新方法定义Class
2016/06/28 Javascript
jQuery基于ID调用指定iframe页面内的方法
2016/07/06 Javascript
关于动态生成dom绑定事件失效的原因及解决方法
2016/08/06 Javascript
js判断checkbox是否选中个数的方法(超简单)
2016/08/19 Javascript
谈谈target=_new和_blank的不同之处
2016/10/25 Javascript
JavaScript基于Dom操作实现查找、修改HTML元素的内容及属性的方法
2017/01/20 Javascript
JavaScript中最常见的三个面试题解析
2017/03/04 Javascript
js实现图片加载淡入淡出效果
2017/04/07 Javascript
Ionic学习日记实现验证码倒计时
2018/02/08 Javascript
详细介绍解决vue和jsp结合的方法
2020/02/06 Javascript
微信小程序地图实现展示线路
2020/07/29 Javascript
Vue切换Tab动态渲染组件的操作
2020/09/21 Javascript
Python命令行参数解析模块optparse使用实例
2015/04/13 Python
Python生成器定义与简单用法实例分析
2018/04/30 Python
使用python的pyplot绘制函数实例
2020/02/13 Python
在echarts中图例legend和坐标系grid实现左右布局实例
2020/05/16 Python
Python+Kepler.gl轻松制作酷炫路径动画的实现示例
2020/06/02 Python
PyCharm 2020.2 安装详细教程
2020/09/25 Python
如何查看python关键字
2021/01/17 Python
python 实现Requests发送带cookies的请求
2021/02/08 Python
俄语地区最大的中国商品在线购物网站之一:Umka Mall
2019/11/03 全球购物
平面设计专业求职信
2014/08/09 职场文书
继续教育个人总结
2015/03/03 职场文书
2015年部门工作总结范文
2015/03/31 职场文书
毕业设计答辩开场白
2015/05/29 职场文书
Golang 使用Map实现去重与set的功能操作
2021/04/29 Golang
手把手教你从零开始react+antd搭建项目
2021/06/03 Javascript
Spring Cloud Gateway去掉url前缀
2021/07/15 Java/Android
nginx.conf配置文件结构小结
2022/04/08 Servers