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 相关文章推荐
document.documentElement和document.body区别介绍
Sep 16 Javascript
javascript内置对象arguments详解
Mar 16 Javascript
JS输入用户名自动显示邮箱后缀列表的方法
Jan 27 Javascript
JS实现点击按钮自动增加一个单元格的方法
Mar 09 Javascript
常用的JQuery函数及功能小结
Mar 24 Javascript
JS库particles.js创建超炫背景粒子插件(附源码下载)
Sep 13 Javascript
Vue 中使用vue2-highcharts实现top功能的示例
Mar 05 Javascript
关于Google发布的JavaScript代码规范你要知道哪些
Apr 04 Javascript
详解基于vue-cli3快速发布一个fullpage组件
Mar 08 Javascript
详解javascript 变量提升(Hoisting)
Mar 12 Javascript
js实现提交前对列表数据的增删改查
Jan 16 Javascript
js 数组当前行添加数据方法详解
Jul 28 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
discuz论坛 用户登录 后台程序代码
2008/11/27 PHP
php数组函数序列 之array_count_values() 统计数组中所有值出现的次数函数
2011/10/29 PHP
PHP中使用GD库绘制折线图 折线统计图的绘制方法
2015/11/09 PHP
php注册登录系统简化版
2020/12/28 PHP
Centos 6.5系统下编译安装PHP 7.0.13的方法
2016/12/19 PHP
初学prototype,发个JS接受URL参数的代码
2006/09/25 Javascript
基于JQuery的动态删除Table表格的行和列的代码
2011/05/12 Javascript
基于javascript的COOkie的操作实现只能点一次
2014/12/26 Javascript
js实现文本框输入文字个数限制代码
2015/12/25 Javascript
JS组件Bootstrap Select2使用方法解析
2016/05/30 Javascript
jQuery简单实现彩色云标签效果示例
2016/08/01 Javascript
Vue2几种常见开局方式详解
2017/09/09 Javascript
JS数组求和的常用方法总结【5种方法】
2019/01/14 Javascript
JavaScript 判断iPhone X Series机型的方法
2019/01/28 Javascript
点击按钮弹出模态框的一系列操作代码实例
2019/03/29 Javascript
在node中使用jwt签发与验证token的方法
2019/04/03 Javascript
Vue.js轮播图走马灯代码实例(全)
2019/05/08 Javascript
javascript中的数据类型检测方法详解
2019/08/07 Javascript
vue使用高德地图根据坐标定位点的实现代码
2019/08/22 Javascript
JS代码屏蔽F12,右键,粘贴,复制,剪切,选中,操作实例
2019/09/17 Javascript
vue实现简单跑马灯效果
2020/05/25 Javascript
Python根据区号生成手机号码的方法
2015/07/08 Python
用python写的一个wordpress的采集程序
2016/02/27 Python
使用python和Django完成博客数据库的迁移方法
2018/01/05 Python
Python字典的核心底层原理讲解
2019/01/24 Python
Python urllib.request对象案例解析
2020/05/11 Python
python使用hdfs3模块对hdfs进行操作详解
2020/06/06 Python
Python函数调用追踪实现代码
2020/11/27 Python
5个你不知道的HTML5的接口介绍
2013/08/07 HTML / CSS
皇马官方商城:Real Madrid Store
2016/09/02 全球购物
目标责任书格式
2014/07/28 职场文书
法院授权委托书范文
2014/08/02 职场文书
2014年社区工会工作总结
2014/12/18 职场文书
2015年度个人思想工作总结
2015/04/08 职场文书
地道战观后感2000字
2015/06/04 职场文书
python引入其他文件夹下的py文件具体方法
2021/05/23 Python