快速排序——JavaScript实现
基本原理:
1、从一个数组中任意挑选一个元素作为中轴元素;
2、将剩下的元素以中轴元素作为比较的标准,将小于等于中轴元素的放到中轴元素的左边,将大于中轴元素的放到中轴元素的右边;
3、以当前中轴元素的位置为界,将左半部分子数组和右半部分子数组看成两个新的数组
4、重复上述操作,直到子数组的元素个数小于等于1(因为一个元素的数组必定是有序的)。 var quickSort = function (arr) {
if (arr.length <= 1) {//如果数组长度为1,返回数组
return arr;
}
var pivotIndex = Math.floor(arr.length / 2);//取中轴位置
var pivot = arr.splice(pivotIndex, 1);//取中轴位置的元素
var left = []; //定义左边数组
var right = []; //定义右边数组
for (var i = 0; i < arr.length; i++) {//遍历数组
if (arr[i] < pivot) {//遍历数组每个数与中轴元素值比较大小
left.push(arr[i]);//小于中轴元素值放在左边数组
} else {
right.push(arr[i]);//大于中轴元素值放在右边数组
}
}
return quickSort(left).concat([pivot], quickSort(right));//递归以上操作,对左右数组进行排序,直到左边或者右边数组长度小于等于1
};
- Math.floor( )方法:是向下取整计算,它返回的是小于或等于函数参数,并且与之最接近的整数。例如:var x = Math.floor(2.6); x = 2;
var x = Math.floor(0.6); x = 0;
var x = Math.floor(5.1); x = 5;
var x = Math.floor(-5.1); x = -6;
var x = Math.floor(-5.9); x = -6; - splice( )方法:方法向(从)数组中添加(删除)项目,然后返回被删除的项目。
注释:该方法会改变原始数组。
- var arr = [1,2,3,4,5];
arr.splice(2,0,"A");
arr = [1,2,A,3,4,5];
- var arr = [1,2,3,4,5];
arr.splice(2,1,"A");
arr = [1,2,A,4,5];
- var arr = [1,2,3,4,5];
arr.splice(2,3,"A");
arr = [1,2,A];
- concat( )方法:用于连接两个或多个数组。不会改变现有的数组,只会返回被连接数组的一个副本。
- 递归:在运行的过程中调用自己。就是包子馅的包子,极限是变成馒头。
时间复杂度:最优O(n2);最差O(nlogn);平均O(nlogn);
空间复杂度:最优O(logn) ;最差O(n);
快速排序——JavaScript实现的更多相关文章
- 快速排序 javascript实现
Quicksort(快速排序) 是由 东尼·霍尔 所发展的一种排序. 它比其他的Ο(n log n)算法更快, 因为它的内部循环(inner loop)可以在大部分的架构上很有效率地被实现出来.当然, ...
- 快速排序 JavaScript 实现
作为算法目录下的第一篇博文,快速排序那是再合适不过了.作为最基本最经典的算法之一,我觉得每个程序员都应该熟悉并且掌握它,而不是只会调用库函数,知其然而不知其所以然. 排序算法有10种左右(或许更多), ...
- 快速排序javascript实现
快速排序基本思想: 以升序为例 数组arr,数组个数n; 1.选取一个待排序的元素.一般选第一个位置作为基准值temp=arr[0]. 2.选取带排序数组的两端元素的位置作为哨兵的位置,左端为哨兵i, ...
- JavaScript实现10大算法可视化
参考博客: https://www.cnblogs.com/Unknw/p/6346681.html#4195503 十大经典算法 一张图概括: 名词解释: n:数据规模 k:“桶”的个数 In-pl ...
- JS的十大经典算法排序
引子 有句话怎么说来着: 雷锋推倒雷峰塔,Java implements JavaScript. 当年,想凭借抱Java大腿火一把而不惜把自己名字给改了的JavaScript(原名LiveScript ...
- JS家的排序算法
由于浏览器的原生支持(无需安装任何插件),用JS来学习数据结构和算法也许比c更加便捷些.因为只需一个浏览器就能啪啪啪的调试了.比如下图我学习归并排序算法时,只看代码感觉怎么都理解不了,但是结合chro ...
- js排序算法汇总
JS家的排序算法 十大经典算法排序总结对比 一张图概括: 主流排序算法概览 名词解释: n: 数据规模k:“桶”的个数In-place: 占用常数内存,不占用额外内存Out-place: 占用额外 ...
- JS中常见排序算法详解
本文将详细介绍在JavaScript中算法的用法,配合动图生动形象的让你以最快的方法学习算法的原理以及在需求场景中的用途. 有句话怎么说来着: 雷锋推倒雷峰塔,Java implements Java ...
- js 算法排序总结
1.冒泡排序JavaScript代码实现: function bubbleSort(arr) { var len = arr.length; for (var i = 0; i < len; i ...
随机推荐
- 云栖大会day1 下午
下午参与的是创新创业专场 会议议程是 创新创业专场-2018阿里云创新中心年度盛典 13:30-14:10 阿里双创新征程 李中雨 阿里云创业孵化事业部总经理 14:10-14:40 人货场的渗透与重 ...
- 基于STM32F429+HAL库编写的定时器主从门控模式级联输出固定个数PWM脉冲的程序
硬件设备 42步进电机,步进电机驱动器,正点原子F429开发板 开发软件 keil5,Cube 综述 一般要精准的控制电机,就要控制单片机的引脚输出指定个数的PWM波,有多种可实现的方法 ...
- linux 下oracle导入dmp文件
2017年08月01日 19:10:49 xuxie13 阅读数:17788 最近要到某公司进行poc演示,整了个新项目,需要我数据库修改项目,这才有了这篇博客. 首先进入linux下oracle ...
- JAVA字符串的处理
问题描述: 从键盘数入若干文字,最后输入的一行"end"代表结束标记. 统计该段文字中英文字母的个数 将其中的所有单词the全部改为a,输出结果 将该段文字所有的数字串找出来输出 ...
- docker学习-常用命令1
一.容器管理 1.1 Docker start/stop/restart/rm 命令实例:启动|停止|重启|删除 容器mydb01# docker start|stop|restart|rm mydb ...
- 卷积神经网络系列之softmax,softmax loss和cross entropy的讲解
我们知道卷积神经网络(CNN)在图像领域的应用已经非常广泛了,一般一个CNN网络主要包含卷积层,池化层(pooling),全连接层,损失层等.虽然现在已经开源了很多深度学习框架(比如MxNet,Caf ...
- 基本HTML结构
配置:在vs code中声明页面为html,然后添加open in browser,view in browser插件通过快捷键alt+b实现在浏览器中查看编写好的html界面 基本成分: <! ...
- 2-java-写代码技巧和交题注意点
用java交题要严格按照规定写代码: 比如蓝桥杯就是: 1.不能有包名: 2.Class的名字必须是 Main; 代码补全建议: 1.main函数的头可以建立class时候直接勾选,也可以: 只输入 ...
- 解决npm ERR! Unexpected end of JSON input while parsing near的方法
这两天执行 npm install 时会报错误: npm ERR! Unexpected end of JSON input while parsing near 清除cache npm cache ...
- CentOS7 查看显卡信息
A卡: [root@t1 ~]# lspci | grep -i vga 00:02.0 VGA compatible controller: Cirrus Logic GD 5446 N卡: [ro ...