• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >JavaScript > 详解JS中的快速排序与冒泡

详解JS中的快速排序与冒泡

作者:奋斗的小小牛 字体:[增加 减小] 来源:互联网 时间:2017-05-11

奋斗的小小牛通过本文主要向大家介绍了node.js开发实战详解,js prototype详解,js指标详解附图,js详解,js指标详解等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

1.快速排序思想:

  1.1 先找数组的最中间的一个数为基准

  1.2 把数组通过此基准分为小于基准的left数组和大于基准的right数组,

  1.3 递归重复上面的两个步骤,

代码如下:

function quickSort(arr) {
  if (arr.length <=1 ){
    return arr;
  }
  var middleIndex = Math.floor(arr.length / 2);
  var left = [];
  var right = [];
  var middle = arr.splice(middleIndex,1)[0];
  for (var i = 0; i < arr.length; i++) {
    if ( arr[i] > middle) {
      right.push(arr[i]);
    } else {
      left.push(arr[i]);
    }
  }
  return quickSort(left).concat(middle,quickSort(right));
}
</div>

2. 冒泡排序思想:

  2.1 两两比较,交换位置

  2.2 循环数组

代码如下:

function bubbleSort(arr) {
  for (var i = 0; i < arr.length - 1; i++) {
    for (var j = 0; j < arr.length -1 -i; j++) {
      if( arr[j] > arr[j+1]){
        var temp = arr[j];
        arr[j] = arr[j+1];
        arr[j+1] = temp;
      }
    }
  }
  return arr;
}
</div>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • JS触摸事件、手势事件详解
  • 详解Node.js串行化流程控制
  • 详解node.js平台下Express的session与cookie模块包的配置
  • JS条形码(一维码)插件JsBarcode用法详解【编码类型、参数、属性】
  • JS排序之冒泡排序详解
  • JS排序之快速排序详解
  • JS排序之选择排序详解
  • 详解node.js搭建代理服务器请求数据
  • 详解Node.js实现301、302重定向服务
  • js时间查询插件使用详解

相关文章

  • 2017-05-11javascript基本数据类型和转换
  • 2017-05-11JavaScript编写一个贪吃蛇游戏
  • 2017-05-11jQuery插件扩展操作入门示例
  • 2017-08-14js中输入数字自动货币格式化
  • 2017-05-11angularjs+bootstrap菜单的使用示例代码
  • 2017-05-11微信小程序-横向滑动scroll-view隐藏滚动条
  • 2017-05-11简单实现js悬浮导航效果
  • 2017-05-11微信小程序 checkbox组件详解及简单实例
  • 2017-05-11bootstrap table 数据表格行内修改的实现代码
  • 2017-05-11微信小程序 引用其他js文件实现代码

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • javascript自执行函数
    • Ajax和Comet技术总结
    • 微信小程序 picker 组件详解及简单实例
    • jQuery层级选择器实例代码
    • ES6--字符串、正则、数值、数组的扩展
    • 全局变量、局部变量、const、static、extern
    • jquery仿ps颜色拾取功能
    • AngularJS封装$http.post()实例详解
    • Bootstrap禁用响应式布局的实现方法
    • nodejs个人博客开发第一步 准备工作

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有