JavaScript实现常见排序算法
列表
冒泡排序
选择排序
插入排序
快速排序
希尔排序
归并排序
冒泡排序
// 输入:[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实现常见排序算法的更多相关文章
- JavaScript版几种常见排序算法
今天发现一篇文章讲“JavaScript版几种常见排序算法”,看着不错,推荐一下原文:http://www.w3cfuns.com/blog-5456021-5404137.html 算法描述: * ...
- JS常见排序算法
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 常见排序算法(JS版)
常见排序算法(JS版)包括: 内置排序,冒泡排序,选择排序,插入排序,希尔排序,快速排序(递归 & 堆栈),归并排序,堆排序,以及分析每种排序算法的执行时间. index.html <! ...
- 常见排序算法(附java代码)
常见排序算法与java实现 一.选择排序(SelectSort) 基本原理:对于给定的一组记录,经过第一轮比较后得到最小的记录,然后将该记录与第一个记录的位置进行交换:接着对不包括第一个记录以外的其他 ...
- 常见排序算法-Python实现
常见排序算法-Python实现 python 排序 算法 1.二分法 python 32行 right = length- : ] ): test_list = [,,,,,, ...
- python常见排序算法解析
python——常见排序算法解析 算法是程序员的灵魂. 下面的博文是我整理的感觉还不错的算法实现 原理的理解是最重要的,我会常回来看看,并坚持每天刷leetcode 本篇主要实现九(八)大排序算法 ...
- python——常见排序算法解析
算法是程序员的灵魂. 下面的博文是我整理的感觉还不错的算法实现 原理的理解是最重要的,我会常回来看看,并坚持每天刷leetcode 本篇主要实现九(八)大排序算法,分别是冒泡排序,插入排序,选择排序, ...
- 常见排序算法总结 -- java实现
常见排序算法总结 -- java实现 排序算法可以分为两大类: 非线性时间比较类排序:通过比较来决定元素间的相对次序,由于其时间复杂度不能突破O(nlogn),因此称为非线性时间比较类排序. 线性时间 ...
- javascript 中合并排序算法 详解
javascript 中合并排序算法 详解 我会通过程序的执行过程来给大家合并排序是如何排序的... 合并排序代码如下: <script type="text/javascript& ...
随机推荐
- C# 连接 SQLServer 及操作
随笔:连接: // 将tb_User表数据添加到DataGridView中 string sqlconn = "Data Source=localhost;Initial Catalog=d ...
- 编写JQuery插件-2
继续上一节的代码 (function(){ /* code */ })() 来我们介绍一下吧,首先定义一个匿名函数 fnction(){/* 这里放置代码 */} 然后用括号括起来, (fnction ...
- Superwebsocket 模拟微信聊天室
在园子里潜水几年了,工作以来算是有些积累,突然想写点东西方便以后温故而知新,希望自己能够坚持下去. 关于Superwebsocket的介绍我就不多说了,请点击:http://www.cnblogs.c ...
- .net 基础服务开源战略规划备忘录
公司现状 1. 技术人员水平限制: 基础研发人员技术细节,性能处理能力不足,技术视野不够开阔;甚至一些高可用,高性能方案的概念都未听闻,更别提发展方向和思路了,令人痛心. 2. 技术反馈渠道限制: 公 ...
- angular2使用官网npm install下载依赖失败的处理方法
上一两个月在学习angular2,在下载依赖阶段看官网是直接自动下载的,[npm install] 就能把依赖全部弄下来.不过作为新手的我,是倒腾来倒腾去都倒不出来,因为老是报同一个错.官网也还有手动 ...
- c#入门系列——番外篇:vs的安装与使用
vs的安装 1.安装条件 vs全称visual studio 它是一个开发平台,不仅可以用于c#开发,别的也可以.安装vs前,首先需要一个安装包.安装包可以在网上下载.没有购买版权的 ...
- [hadoop] - Container [xxxx] is running beyond physical/virtual memory limits.
当运行mapreduce的时候,有时候会出现异常信息,提示物理内存或者虚拟内存超出限制,默认情况下:虚拟内存是物理内存的2.1倍.异常信息类似如下: Container [pid=13026,cont ...
- 《C++ Primer》读书笔记—第二章 变量和基本类型
声明: 文中内容收集整理自<C++ Primer 中文版 (第5版)>,版权归原书所有. 学习一门程序设计语言最好的方法就是练习编程. 1.8比特的char类型计算机表示的实际范围是-12 ...
- 如何在网上得到你想要的图片,如logo
比如我们想得到网页:http://www.ahnu.edu.cn/里的安徽师范大学logo,可以这样做: 1.Ctrl+U,便进入了网页源代码页,也可以鼠标右键点"查看网页源代码" ...
- Altium Designer(DXP)小技巧之模块化布局
原创博客转载需注明地址 在我们用Altium Designer进行电路板的绘制的时候经常会遇到模块化布局的问题 就比如电源模块(电源芯片及其外围芯片)放在一起 传感器模块(传感器芯片及其外围芯片)放在 ...