JS数组——冒泡、插入、快速排序
前言:因为要对后端返回来的数据进行处理,之前之后冒泡,不够用,去看了插入跟快速,写下这篇笔记。
使用背景:
1.冒泡排序
数据比较少,小于1000
2.插入排序
数据比较少,大于1000不推荐
3.快速排序
相对于前两者,适合处理量大的数据
一: 冒泡排序
主要思想:将每个数跟数组中的其他数两两比较大小,交换位置。
var arr = [1,5,10,15,100,25,50] // 需要注意,想要完成冒泡排序,需要两轮for循环
for (var i = 0; i < arr.length; i++) {
// 拿到每个数arr[i],再去遍历 i 后面的数去做比较
for (var j = i + 1; j < arr.length; j++) {
// 比较大小
// 升序
if (arr[i] > arr[j]) {
var tmp = arr[i]
arr[i] = arr[j]
arr[j] = tmp
}
}
} console.log(arr) // [1, 5, 10, 15, 25, 50, 100]
其他应用: 数组存储的是对象,利用arr[i].value 去比较
关键点: 控制循环次数,i是数组的长度,j是从i的位置+1开始,因为前面的数值已经排好了
可以优化的点: 假设数组本身就是排序好的,这时候再去比较大小就很不合理,设置标识
二、插入排序
主要思想:
1.把数组分成一个有序数列和一个无序数列
2.默认把数组第一项当成一个有序数列
3.拿第一项去跟其他无序项比较大小
4.调换位置
别光想,有点绕很正常的,有手写一下过程
三、快速排序(重点,面试比较多?)
主要思想:
1.随机用数组的其中一个值当基准值(中间值、中介、中线),我喜欢用数组第一项
2.left等于0,right等于数组的长度-1,从左往右
举个例子:
var arr = [5,3,6,2,7,9,10]
// 假设中间值是数组第一项 5
// 那我们想要的数组应该是这样的
arr = [2,3,5,6,7,9,10]
// 以 5 为中介,左边比5小或者等于,右边比5大或者等于
用代码实现
var arr = [5,3,2,4,6,9,7,10]
function quickSort(arr, i, j) {
var left = i
var right = j
if (left < right) {
//如果数组有两项以上
var base = arr[left]
// 设置中间值,开始比较
while (left !== right) {
// 这里是找比中间值小的值并设置
while (right > left && arr[right] >= base) {
// 假设此时right = 4
// right-- = 3 arr[left] = arr[3] = 4,这个时候再出去while判断,条件已经不成立了,我们也拿到了比base小的值了
right--
arr[left] = arr[right]
}
// 这里是找比中间值大的值并设置
while (left < right && arr[left] <= base) {
left++
arr[right] = arr[left]
}
}
// 设置中间值的位置
arr[right] = base
// 递归调用,直到数列别分解成一个数值组成的数列
arguments.callee(arr, i, left-1)
arguments.callee(arr, right+1, j)
return arr
}
}
console.log(quickSort(arr, 0, arr.length-1)
JS数组——冒泡、插入、快速排序的更多相关文章
- js数组冒泡
var arr 1= [1, 2, 3, 4, 5]; 最简单的 每组数字之间用逗号隔开 第一个数的索引值为0.数字为1 以此类推 中括号的内容是存var arr2 = Array(1, 2, 3); ...
- js数组冒泡排序,快速排序的原理以及实现
冒泡排序: 随便从数组中拿一位数和后一位比较,如果是想从小到大排序,那么就把小的那一位放到前面,大的放在后面,简单来说就是交换它们的位置,如此反复的交换位置就可以得到排序的效果. var arr = ...
- js数组冒泡排序、快速排序、插入排序
1.冒泡排序 //第一种 function bubblesort(ary){ for(var i=0;i<ary.length-1;i++){ for(var j=0;j<ary.leng ...
- 如何在JS数组特定索引处指定位置插入元素?
如何在JS数组特定索引处指定位置插入元素? 需求: 将一个元素插入到现有数组的特定索引处.听起来很容易和常见,但需要一点时间来研究它. // 原来的数组var array = ["one&q ...
- js 给json添加新的字段,或者添加一组数据,在JS数组指定位置删除、插入、替换元素
JS定义了一个json数据var test={name:"name",age:"12"};需要给test再添加一个字段,需要什么办法,可以让test的值为{na ...
- 数组的操作。1,JS数组去重。2,把数组中存在的某个值,全部找出来。3在JS数组指定位置插入元素。。。
1,数组去重 let arr = [1,2,3,4,5,6,1,2,3,'a','b','a']; let temp = []; // 作为存储新数组使用 for(let i = 0; i < ...
- js向一个数组中插入元素的几个方法-性能比较
向一个数组中插入元素是平时很常见的一件事情.你可以使用push在数组尾部插入元素,可以用unshift在数组头部插入元素,也可以用splice在数组中间插入元素. 但是这些已知的方法,并不意味着没有更 ...
- js数组快速排序/去重
数组的排序 快速排序 思路: (1)在数据集之中,选择一个元素作为”基准”(pivot). (2)所有小于”基准”的元素,都移到”基准”的左边:所有大于”基准”的元素,都移到”基准”的右边. (3) ...
- js数组操作大全
原文(http://www.cnblogs.com/webhotel/archive/2010/12/21/1912732.html) 用 js有很久了,但都没有深究过js的数组形式.偶尔用用也就是简 ...
随机推荐
- NYOJ 496 [巡回赛-拓扑排序]
链接:click here 题意: 巡回赛 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描写叙述 世界拳击协会(WBA)是历史最悠久的世界性拳击组织,孕育了众多的世界冠军, ...
- libsqlite3.dylib与libsqlite3.0.dylib的差别
在我们加入数据库框架时,在搜索框中输入sqlitekeyword,以下列表区会显示libsqlite3.dylib,libsqlite3.0.dylib. 此时我们选择libsqlite3.0.dyl ...
- easyUI datagrid 前端假分页
datagrid有两种分页方式,真分页和假分页. 所谓真分页,就是真的每次只获取一张分页的数据. 所谓假分页,就是将所有数据全部获取下来,然后利用其分页控件进行分页. 下面具体说说假分页: 1.dat ...
- 自定义的Notification
要创建一个自定义的Notification,可以使用RemoteViews.要定义自己的扩展消息,首先要初始化一个RemoteViews对象,然后将它传递给Notification contentVi ...
- 第十三周 Leetcode 363. Max Sum of Rectangle No Larger Than K(HARD)
Leetcode363 思路: 一种naive的算法就是枚举每个矩形块, 时间复杂度为O((mn)^2), 可以做少许优化时间复杂度可以降低到O(mnnlogm), 其中m为行数, n为列数. 先求出 ...
- ubuntu 14.04中: 像ubuntu16.04 一样可以在文件夹内打开此路径下的shell
sudo apt-get install nautilus-open-terminal 然后重启 ok!
- PHP cURL使用小结
cURL简介 cURL是什么? cURL(Client URL Library Functions)由 Daniel Stenberg 创建的libcurl库,官方定义为:curl is a comm ...
- JavaSwing输入对话框,点击取消抛出异常的解决方法
在做产品管理系统的时候,遇到一个问题: 在得到一个输入框对话框的时候 String textPrice = JOptionPane.showInputDialog("请输入要调整的价格增(减 ...
- (前缀和 内存分配)51NOD 1081 子段求和
给出一个长度为N的数组,进行Q次查询,查询从第i个元素开始长度为l的子段所有元素之和. 例如,1 3 7 9 -1,查询第2个元素开始长度为3的子段和,1 {3 7 9} -1.3 + 7 + 9 ...
- nginx+thinkPhp配置虚拟主机和伪静态规则重写
/usr/local/nginx/conf/nginx.conf 进行配置 server { listen 80 default_server; #listen [: ...