列表

  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. windows下安装redis以及redis扩展,设置redis为windows自启服务

    windows下安装reids windows下redis下载地址:https://github.com/MSOpenTech/redis/releases. 启动redis服务:在redis目录下启 ...

  2. struts2系列笔记(1)

    struts2框架 如果你之前在MVC模式的时候一直都是通过servlet,获取和返回数据,那么现在开始学习struts2框架, Struts是一个实现MVC设计模式的优秀的框架.它的许多优点我就不说 ...

  3. 11g默认审计选项

    [注:参考了maclean的网文]11g默认审计选项AUDIT_TRAIL参数的缺省值为DB,审计数据记录在数据库中的AUD$审计字典基表上.在11g中CREATE SESSION将被作为受审计的权限 ...

  4. 关于JavaScript中的编码和解码函数

    js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent 1 ...

  5. block、inline、inline-block对比

    display:block 1.block元素会独占一行,多个block元素会各种新起一行.默认情况下,block元素宽度自动填满其父元素容器: 2.block元素可以设置width和height属性 ...

  6. spring+struts2+ibatis 框架整合以及解析

    一. spring+struts2+ibatis 框架 搭建教程 参考:http://biancheng.dnbcw.net/linux/394565.html 二.分层 1.dao: 数据访问层(增 ...

  7. java集合框架05——ArrayList和LinkedList的区别

    前面已经学习完了List部分的源码,主要是ArrayList和LinkedList两部分内容,这一节主要总结下List部分的内容. List概括 先来回顾一下List在Collection中的的框架图 ...

  8. jQuery写选项卡

    <!DOCTYPE html> <htmllang="en"> <head> <metacharset="UTF-8" ...

  9. 每天一个Linux命令(05)--rm命令

    自从学会了用mkdir创建目录之后,整个系统里就只能看到一堆空目录了,囧~ 那么今天我们来学一下如何清理这些空目录吧--rm命令,该命令的功能为删除一个目录中的一个或多个文件或目录,它也可以将某个目录 ...

  10. 用JS获取地址栏中的参数的简易方法

    这个方法用起来超级简单,传入参数即可直接获取地址栏中的参数 代码如下 function GetQueryString(name) { var reg = new RegExp("(^|&am ...