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 相关文章推荐
javascript之大字符串的连接的StringBuffer 类
May 08 Javascript
教你如何解密js/vbs/vbscript加密的编码异处理小结
Jun 25 Javascript
js获取客户端网卡的IP地址、MAC地址
Mar 26 Javascript
js实现刷新iframe的方法汇总
Apr 27 Javascript
jquery实现全选、不选、反选的两种方法
Sep 06 Javascript
jQuery实现select下拉框获取当前选中文本、值、索引
May 08 jQuery
vue 虚拟dom的patch源码分析
Mar 01 Javascript
jQuery实现的简单对话框拖动功能示例
Jun 05 jQuery
vue.js绑定事件监听器示例【基于v-on事件绑定】
Jul 07 Javascript
Vue代码整洁之去重方法整理
Aug 06 Javascript
vue开发移动端底部导航条功能
Apr 08 Javascript
JavaScript数组排序功能简单实现
May 14 Javascript
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
smarty基础之拼接字符串的详解
2013/06/18 PHP
php中session过期时间设置及session回收机制介绍
2014/05/05 PHP
PHP获取数组最大值下标的方法
2015/05/12 PHP
简介PHP的Yii框架中缓存的一些高级用法
2016/03/29 PHP
php实现base64图片上传方式实例代码
2017/02/22 PHP
ThinkPHP框架获取最后一次执行SQL语句及变量调试简单操作示例
2018/06/13 PHP
jQuery对象[0]是什么含义?
2010/07/31 Javascript
Javascript insertAfter() 实现函数代码
2011/10/12 Javascript
如何从jQuery的ajax请求中删除X-Requested-With
2013/12/11 Javascript
JQuery的Ajax中Post方法传递中文出现乱码的解决方法
2014/10/21 Javascript
JavaScript中发布/订阅模式的简单实例
2014/11/05 Javascript
js实现图片和链接文字同步切换特效的方法
2015/02/20 Javascript
SpringMVC restful 注解之@RequestBody进行json与object转换
2015/12/10 Javascript
jQuery实现移动端手机商城购物车功能
2016/09/24 Javascript
javascript 中Cookie读、写与删除操作
2017/03/29 Javascript
浅谈Webpack自动化构建实践指南
2017/12/18 Javascript
JavaScript实现的DOM绘制柱状图效果示例
2018/08/08 Javascript
vue中echarts图表大小适应窗口大小且不需要刷新案例
2020/07/19 Javascript
python文件比较示例分享
2014/01/10 Python
Python写入CSV文件的方法
2015/07/08 Python
Python 类与元类的深度挖掘 II【经验】
2016/05/06 Python
Python爬取个人微信朋友信息操作示例
2018/08/03 Python
Window 64位下python3.6.2环境搭建图文教程
2018/09/19 Python
python GUI库图形界面开发之PyQt5复选框控件QCheckBox详细使用方法与实例
2020/02/28 Python
澳大利亚在线百货商店:Real Smart
2017/08/13 全球购物
英国领先的酒杯和水晶玻璃器皿制造商:Dartington Crystal
2019/06/23 全球购物
部队学习十八大感言
2014/01/11 职场文书
精彩广告词大全
2014/03/19 职场文书
探亲假请假条
2014/04/11 职场文书
拔河比赛口号
2014/06/10 职场文书
民警群众路线教育实践活动对照检查材料
2014/10/04 职场文书
2015年政风行风工作总结
2015/04/21 职场文书
教师专业技术工作总结2015
2015/05/13 职场文书
大学生读书笔记范文
2015/07/01 职场文书
2015年党风廉政建设个人总结
2015/08/18 职场文书
NASA 机智号火星直升机拍到了毅力号设备碎片
2022/04/29 数码科技