列表

  1. 冒泡排序

  2. 选择排序

  3. 插入排序

  4. 快速排序

  5. 希尔排序

  6. 归并排序

冒泡排序

// 输入:[5, 6, 3, 4, 8, 0, 1, 4, 7]
// 输出:[0, 1, 3, 4, 4, 5, 6, 7, 8]
外层1:
内层1:3 6 5 8 0 1 4 7
内层2:0 6 5 8 3 1 4 7
外层2:
内层1:0 5 6 8 3 1 4 7
内层2:0 3 6 8 5 1 4 7
内层3:0 1 6 8 5 3 4 7 // 每一次外层循环是为了找到当前最小的值
// 外层循环当前值与内层循环的值进行比较 function bubbleSort(arr) {
for(var i = 0, l = arr.length;i < l - 1;i++) {
for(var j = i + 1;j < l;j++) {
if(arr[i] > arr[j]) {
var temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
return arr;
}

选择排序


// 每一次从待排的数据元素中选出最小或者最大的一个元素
// 存放在系列的起始位置, 直到全部待排的数据排完。 function selectSort(arr) {
for(var i = 0;i < arr.length - 1;i++) {
// 无序区的最小数据数组下标
var minIndex = i;
for(var j = i + 1;j < arr.length;j++) {
// 在无序区查找最小数据并保存其下标
if(arr[j] < arr[minIndex]) {
minIndex = j;
}
}
// 将最小的项移到左边
if(minIndex != i) {
var temp = arr[i];
arr[i] = arr[minIndex];
arr[minIndex] = temp;
}
}
return arr;
}

冒泡排序是直接交换, 而选择排序是保存下标,最后交换

插入排序


// 取第一个数字是排序好了的
// 可以理解为左边是排序好的数组
// 右边是待排序的数组 function insertSort(arr) {
for(var i = 1;i < arr.length;i++) {
if(arr[i - 1] > arr[i]) {
// 记录要被插的数字
var guard = arr[i];
// 记录有序数组的最后一个数字的下标
var j = i - 1; // 开始判断并且右移动
while(j >= 0 && arr[j] > guard) {
arr[j + 1] = arr[j];
j--;
}
arr[j + 1] = guard;
}
}
return arr;
}

快速排序

// 1. 在数组中,选一个元素作为基准
// 2. 所有小于基准的元素,都移到基准的左边;所有大于基准的元素,都移到基准的右边。
// 3. 对基准左边和右边的两个子集,不断重复第一步和第二步,直到所有子集只剩下一个元素为止。
function quickSort(arr) {
if(arr.length <= 1) {
return arr;
}
var pivotIndex = Math.floor(arr.length / 2);
// 找到基准元素,并将其从数组中分离出来
var pivot = arr.splice(pivotIndex, 1)[0];
var leftArr = [];
var rightArr = [];
for(var i = 0;i < arr.length;i++) {
if(arr[i] > pivot) {
rightArr.push(arr[i]);
} else {
leftArr.push(arr[i]);
}
}
return quickSort(leftArr).concat([pivot], quickSort(rightArr));
}

希尔排序


// 希尔排序也叫增量递减排序
// 核心思想就是分组
// 然后在组里进行常规的插入排序 var arr = [10, 6, 3, 4, 8, 0, 1, 4, 7];
function shellSort(arr) { // 取增量
var gap = Math.floor(arr.length / 2); // 只要增量大于1,就可以一直算
while(gap > 0) { // 从第一个子列的最后一个数开始计算
for(var i = gap;i < arr.length;i++) { // 存储当前子列的最后一个数
var temp = arr[i]; // 对子列进行普通的插入排序
// i是当前子列的最后一个数的坐标
// j等于i,j从当前子列的最后一个数往前计算
// 这里该怎么理解呢, 我来举个例子
// 如果数组排序到了: 8, 0, 9, 4, 7, 6, 3, 4, 10
// 此时j为6, gap为2
// 这样就好理解了 for(var j = i;j >= gap && arr[j - gap] > temp; j -= gap) { // 将下标j对应的值改变为大的那个
arr[j] = arr[j - gap];
} // 如果中间出现了交换, j的值要变化
// 那么相当于交换
// 如果j的值没有变化,那么a[j]的值本身没有变化
arr[j] = temp;
} gap = Math.floor(gap / 2);
}
return arr;
}

归并排序

// 归并排序的基本操作是合并两个已经排好序的数组

// 增加额外的空间,用于合并两个已经排序好的数组
function merge(left, right) {
var result = [];
while(left.length > 0 && right.length > 0) {
if(left[0] < right[0]) {
result.push(left.shift());
} else {
result.push(right.shift());
}
}
return result.concat(left, right);
} // 递归
function mergeSort(arr) {
if(arr.length == 1) {
return arr;
}
var middle = Math.floor(arr.length / 2);
var left = arr.slice(0, middle);
var right = arr.slice(middle);
return merge(mergeSort(left), mergeSort(right));
}

JavaScript实现常见排序算法的更多相关文章

  1. JavaScript版几种常见排序算法

    今天发现一篇文章讲“JavaScript版几种常见排序算法”,看着不错,推荐一下原文:http://www.w3cfuns.com/blog-5456021-5404137.html 算法描述: * ...

  2. JS常见排序算法

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. 常见排序算法(JS版)

    常见排序算法(JS版)包括: 内置排序,冒泡排序,选择排序,插入排序,希尔排序,快速排序(递归 & 堆栈),归并排序,堆排序,以及分析每种排序算法的执行时间. index.html <! ...

  4. 常见排序算法(附java代码)

    常见排序算法与java实现 一.选择排序(SelectSort) 基本原理:对于给定的一组记录,经过第一轮比较后得到最小的记录,然后将该记录与第一个记录的位置进行交换:接着对不包括第一个记录以外的其他 ...

  5. 常见排序算法-Python实现

    常见排序算法-Python实现 python 排序 算法 1.二分法     python    32行 right = length-  :  ]   ):  test_list = [,,,,,, ...

  6. python常见排序算法解析

    python——常见排序算法解析   算法是程序员的灵魂. 下面的博文是我整理的感觉还不错的算法实现 原理的理解是最重要的,我会常回来看看,并坚持每天刷leetcode 本篇主要实现九(八)大排序算法 ...

  7. python——常见排序算法解析

    算法是程序员的灵魂. 下面的博文是我整理的感觉还不错的算法实现 原理的理解是最重要的,我会常回来看看,并坚持每天刷leetcode 本篇主要实现九(八)大排序算法,分别是冒泡排序,插入排序,选择排序, ...

  8. 常见排序算法总结 -- java实现

    常见排序算法总结 -- java实现 排序算法可以分为两大类: 非线性时间比较类排序:通过比较来决定元素间的相对次序,由于其时间复杂度不能突破O(nlogn),因此称为非线性时间比较类排序. 线性时间 ...

  9. javascript 中合并排序算法 详解

    javascript 中合并排序算法 详解 我会通过程序的执行过程来给大家合并排序是如何排序的...  合并排序代码如下: <script type="text/javascript& ...

随机推荐

  1. 蓝桥网试题 java 基础练习 特殊的数字

    -------------------------------------------------------- 笑脸 :-) ------------------------------------ ...

  2. Salesforce的Auto Number

    在Salesforce中新建Object的时候,可以对Name选择Auto Number,即自动编号.如果没有仔细阅读说明的话,会有一个很容易让人迷惑的地方. 在选择时候,Salesforce提供的示 ...

  3. SQLSERVER 中实现类似Mysql的 INSERT ON DUPLICATE KEY UPDATE

    通过SQLServer创建索引时,有一个IGNORE_DUP_KEY的选项,可以类似实现. IGNORE_DUP_KEY = { ON | OFF } 指定对唯一聚集索引或唯一非聚集索引执行多行插入操 ...

  4. Linux(Ubuntu)下载安装破解Matlab2016

    跳过废话, 直接看教程 前言 笔者平常不是很喜欢用Matlab, 因为所需要的功能都能被Python替代, 而Matlab的肥和慢实在令人难以忍受. 在Linux系统下安装Matlab也比Window ...

  5. java流和文件 保存字节级数据(写)

    重要的知识点: 流的概念:  从数据源到I/O类的输入流(in)    从I/O类到数据接收器的输出流(out) I/O包含子类较多的有四大家族:InputStream,OutputStream,Re ...

  6. html5橡皮檫特效

    体验效果:http://keleyi.com/keleyi/phtml/html5/32.htm 效果描述: 有点像刮刮卡一样,在移动设备上,把某张图片刮掉显示出另一张图片.效果图如下: 这种刮图的效 ...

  7. c++编程思想(一)--对象导言

    回过头来看c++编程思想第一章,虽然只是对c++知识的一个总结,并没有实质性知识点,但是收获还是蛮多的! 下面感觉是让自己茅塞顿开的说法,虽然含义并不是很准确,但是很形象(自己的语言): 1.类描述了 ...

  8. Javascript面对对象. 第二篇

    但是还有一个问题,就是识别的问题,因为根本无法搞清楚他们到底是哪个对象的实例. 1.构造函数 function CreateObject(name,age){ //创建一个对象,使用构造函数的对象都是 ...

  9. 漂亮的代码2:遍历文件夹目录,使用promise

    看到一个问题: 找到文件夹下所有文件: 自己写了一个: function walk(dir, ext, callback) { ext = ext.charAt(0) === "." ...

  10. iOS runtime的应用实例

      一直想弄明白runtime是怎么回事,因为面试的时候这是一道必备问题,但是平时用的机会真的少之又少,我一度以为runtime只是用来装13的利器,没什么卵用.但是随着学习的增多,发现runtime ...