JavaScript实现经典排序算法之冒泡排序


Posted in Javascript onDecember 28, 2016

冒泡排序可谓是最经典的排序算法了,它是基于比较的排序算法,时间复杂度为O(n^2),其优点是实现简单,n较小时性能较好。

1)算法原理
       相邻的数据进行两两比较,小数放在前面,大数放在后面,这样一趟下来,最小的数就被排在了第一位,第二趟也是如此,如此类推,直到所有的数据排序完成。

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

function bubbleSort(arr){  
  var len = arr.length;  
  for (var i = 0; i < len; i++) {  
    for(var j = 0; j < len - i -1; j++){  
      if(arr[j]>arr[j+1]){ //相邻元素进行对比  
        var temp = arr[j+1];//交换元素  
        arr[j+1] = arr[j];  
        arr[j] = temp;  
      }  
    }  
  }  
  return arr;//返回数组  
}  
  
var arr=[1,45,37,5,48,15,37,26,29,2,46,4,17,50,52];//调用排序算法  
console.log(bubbleSort(arr));//控制台输出结果

        这个算法是最基本的实现方法,接着进行改进这个算法,通过设置一个标志性的变量position,用于记录每趟排序中最后一次进行交换的位置。因为position位置之后的记录都已经排序好了,所以进行下一趟排序时只需要扫描到position的位置就好。
改进之后的算法如下:

function bubbleSort2(arr){  
  var i = arr.length -1;//开始时,扫描的最后位置  
  while(i>0){  
    var position = 0;//标志性变量,表示当前排序中交换的位置  
    for(var j = 0; j < i; j ++){  
      if(arr[j]>arr[j+1]){  
        position = j;  
        var temp = arr[j+1];  
        arr[j+1] = arr[j];  
        arr[j] = temp;  
      }  
    }  
    i = position;  
  }  
  return arr;  
}  
  
var arr=[1,45,37,5,48,15,37,26,29,2,46,4,17,50,52];  
console.log(bubbleSort2(arr));

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

function bubbleSort3(arr){  
  var low = 0;  
  var high = arr.length-1;  
  var temp;  
  while(low < high){//找到最大值  
    for(var j = low ; j < high ; j++){  
      if (arr[j]> arr[j+1]) {       
        temp = arr[j+1];  
        arr[j+1] = arr[j];  
        arr[j] = temp;  
       }  
    }  
    --high;//修改high值,向前移一位  
  }  
  while(low > high){//找到最小值  
    for(var j = high ;j > low; j--){  
      if (arr[j]> arr[j+1]) {       
        temp = arr[j+1];  
        arr[j+1] = arr[j];  
        arr[j] = temp;  
       }  
    }  
    ++low;//修改low值,往后移动一位  
  }  
  return arr;  
}  
var arr=[1,45,37,5,48,15,37,26,29,2,46,4,17,50,52];  
console.log(bubbleSort3(arr));

4)算法分析

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

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

Javascript 相关文章推荐
层序遍历在ExtJs的TreePanel中的应用
Oct 16 Javascript
javascript各浏览器中option元素的表现差异
Apr 07 Javascript
jQuery+HTML5实现手机摇一摇换衣特效
Jun 05 Javascript
vue开发心得和技巧分享
Oct 27 Javascript
Vue中之nextTick函数源码分析详解
Oct 17 Javascript
ligerUI---ListBox(列表框可移动的实例)
Nov 28 Javascript
浅谈React Native Flexbox布局(小结)
Jan 08 Javascript
layer.open弹层查看缩略图的原图,自适应大小的实例
Sep 05 Javascript
json_decode 索引为数字时自动排序问题解决方法
Mar 28 Javascript
vue动态设置路由权限的主要思路
Jan 13 Vue.js
原生js实现自定义滚动条
Jan 20 Javascript
分享一个vue实现的记事本功能案例
Apr 11 Vue.js
BootStrap Tooltip插件源码解析
Dec 27 #Javascript
获取当前月(季度/年)的最后一天(set相关操作及应用)
Dec 27 #Javascript
javascript实现文字无缝滚动
Dec 27 #Javascript
JavaScript仿聊天室聊天记录
Dec 27 #Javascript
基于jQuery实现顶部导航栏功能
Dec 27 #Javascript
js正则表达式最长匹配(贪婪匹配)和最短匹配(懒惰匹配)用法分析
Dec 27 #Javascript
基于jQuery实现左侧菜单栏可折叠功能
Dec 27 #Javascript
You might like
新浪新闻小偷
2006/10/09 PHP
一个PHP的ZIP压缩类分享
2014/05/04 PHP
php实现图片文件与下载文件防盗链的方法
2014/11/03 PHP
php堆排序实现原理与应用方法
2015/01/03 PHP
PHP中调用SVN命令更新网站方法
2015/01/07 PHP
Yii2针对游客、用户防范规则和限制的解决方法分析
2016/10/08 PHP
Javascript条件判断使用小技巧总结
2008/09/08 Javascript
在Javascript里访问SharePoint列表数据的实现方法
2011/05/22 Javascript
Javascript insertAfter() 实现函数代码
2011/10/12 Javascript
Js判断CSS文件加载完毕的具体实现
2014/01/17 Javascript
js如何打印object对象
2015/10/16 Javascript
js实现input密码框提示信息的方法(附html5实现方法)
2016/01/14 Javascript
轻松实现js图片预览功能
2016/01/18 Javascript
JavaScript事件处理的方式(三种)
2016/04/26 Javascript
node.js请求HTTPS报错:UNABLE_TO_VERIFY_LEAF_SIGNATURE\的解决方法
2016/12/18 Javascript
浅谈原生JS中的延迟脚本和异步脚本
2017/07/12 Javascript
详解AngularJS之$window窗口对象
2018/01/17 Javascript
Vue监听一个数组id是否与另一个数组id相同的方法
2018/09/26 Javascript
浅谈Angular7 项目开发总结
2018/12/19 Javascript
详解微信小程序文件下载--视频和图片
2019/04/24 Javascript
[01:39:04]DOTA2-DPC中国联赛 正赛 SAG vs CDEC BO3 第二场 2月1日
2021/03/11 DOTA
在win和Linux系统中python命令行运行的不同
2016/07/03 Python
浅谈python的输入输出,注释,基本数据类型
2019/04/02 Python
基于python全局设置id 自动化测试元素定位过程解析
2019/09/04 Python
python 实现分组求和与分组累加求和代码
2020/05/18 Python
Python如何在循环内使用list.remove()
2020/06/01 Python
Python通过递归函数输出嵌套列表元素
2020/10/15 Python
Python+MySQL随机试卷及答案生成程序的示例代码
2021/02/01 Python
婴儿地球:Baby Earth
2018/12/25 全球购物
医药代表个人的求职信分享
2013/12/08 职场文书
幼儿园托班开学寄语
2014/01/18 职场文书
营销部内勤岗位职责
2014/04/30 职场文书
2014幼儿园教师师德师风演讲稿
2014/09/10 职场文书
《我们的民族小学》教学反思
2016/02/19 职场文书
敬业奉献模范事迹材料(2016精选版)
2016/02/26 职场文书
Redis做数据持久化的解决方案及底层原理
2021/07/15 Redis