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 相关文章推荐
基于JQuery的cookie插件
Apr 07 Javascript
js购物车实现思路及代码(个人感觉不错)
Dec 23 Javascript
JavaScript跨域方法汇总
Oct 16 Javascript
JavaScript数据结构学习之数组、栈与队列
May 02 Javascript
JSON 数据格式详解
Sep 13 Javascript
在vue-cli项目中使用bootstrap的方法示例
Apr 21 Javascript
15个顶级开源JavaScript框架和库
Oct 10 Javascript
JQuery事件委托原理与用法实例分析
May 13 jQuery
JavaScript函数式编程(Functional Programming)纯函数用法分析
May 22 Javascript
javascript实现点亮灯泡特效示例
Oct 15 Javascript
weui中的picker使用js进行动态绑定数据问题
Nov 06 Javascript
Vue+scss白天和夜间模式切换功能的实现方法
Jan 05 Vue.js
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
Home Coffee Roasting
2021/03/03 咖啡文化
站长助手-网站web在线管理程序 v1.0 下载
2007/05/12 PHP
set_include_path和get_include_path使用及注意事项
2013/02/02 PHP
IIS6.0 开启Gzip方法及PHP Gzip函数分享
2014/06/08 PHP
php 升级到 5.3+ 后出现的一些错误,如 ereg(); ereg_replace(); 函数报错
2015/12/07 PHP
TP3.2.3框架使用CKeditor编辑器在页面中上传图片的方法分析
2019/12/31 PHP
去除链接虚线全面分析总结
2006/08/15 Javascript
Javascript 圆角div的实现代码
2009/10/15 Javascript
JQuery拖拽元素改变大小尺寸实现代码
2012/12/10 Javascript
基于jquery扩展漂亮的CheckBox(自己编写)
2013/11/19 Javascript
jquery模拟多级复选框效果的简单实例
2016/06/08 Javascript
AngularJS之依赖注入模拟实现
2016/08/19 Javascript
JS对象的深度克隆方法示例
2017/03/16 Javascript
Vue父子组建的简单通信之控制开关Switch的实现
2018/06/04 Javascript
微信小程序实现分享朋友圈的图片功能示例
2019/01/18 Javascript
JavaScript 格式化数字、金额、千分位、保留几位小数、舍入舍去
2019/07/23 Javascript
javascript浅层克隆、深度克隆对比及实例解析
2020/02/09 Javascript
基于javascript实现日历功能原理及代码实例
2020/05/07 Javascript
解决Vue中使用keepAlive不缓存问题
2020/08/04 Javascript
Javascript基于OOP实实现探测器功能代码实例
2020/08/26 Javascript
html中创建并调用vue组件的几种方法汇总
2020/11/17 Javascript
基于Python数据可视化利器Matplotlib,绘图入门篇,Pyplot详解
2017/10/13 Python
Python读写及备份oracle数据库操作示例
2018/05/17 Python
Python图像处理之图像的缩放、旋转与翻转实现方法示例
2019/01/04 Python
Django中如何防范CSRF跨站点请求伪造攻击的实现
2019/04/28 Python
如何在VSCode上轻松舒适的配置Python的方法步骤
2019/10/28 Python
Python3.7+tkinter实现查询界面功能
2019/12/24 Python
Css3实现无缝滚动防抖
2020/09/14 HTML / CSS
HTML5拖拽文件到浏览器并实现文件上传下载功能代码
2013/06/06 HTML / CSS
美国家喻户晓的保健品品牌:Vitamin World(维他命世界)
2016/08/19 全球购物
党员群众路线承诺书
2014/05/20 职场文书
本科毕业生求职信
2014/06/15 职场文书
2015年迎新晚会策划书
2015/07/16 职场文书
《我们的民族小学》教学反思
2016/02/19 职场文书
《小蝌蚪找妈妈》教学反思
2016/02/23 职场文书
Java移除无效括号的方法实现
2021/08/07 Java/Android