javascript数据结构与算法--高级排序算法

高级排序算法是处理大型数据集的最高效排序算法,它是处理的数据集可以达到上百万个元素,而不仅仅是几百个或者几千个。现在我们来学习下2种高级排序算法---- 希尔排序和快速排序。

一:希尔排序;

希尔排序的核心理念是:首先比较距离较远的元素,而非相邻的元素。

基本原理:通过定义一个间隔序列来表示在排序过程中进行比较的元素之间有多远的间隔。

下面我们来看看数组[0,9,1,8,7,6,2,3,5,4] 来使用希尔排序的原理;如下图:

代码分析如下:

1. 执行 "间隔序列=3的步骤"

A. 那么第一次执行 "间隔序列=3" 的步骤,那么找到位置间隔3的元素为 0 ,  8  , 2  , 4

所以这四个数字当中0最小,所以位置不动,还是第一个位置,8是最大的 所以位置就移动到之前的4的位置上,4移动到8的位置上,但是2和4比较 2小          于4的 所以2和4位置继续调换。所以现在的顺序为0 , 2 , 4  , 8,如上图(间隔序列=3)

B. 现在第二次执行 "间隔序列=3" 的步骤,找到元素为 9 , 7 , 3 分析还是和上面的一样 3是最小的,所以移动到原先9的位置上,9就移到到3的位置上,   由     于7小于9 所以不需要移动,所以现在的顺序为 3 , 7 , 9 如上图(间隔序列=3)

C. 现在第三次执行 "间隔序列=3"的步骤,找到元素 1 , 6 , 5 ,由于1是最小的 所以不需要移动,6大于5,所以2者要调换位置 所以顺序为 1 , 5  , 6

执行完上面的步骤后,正确的顺序为 [0,3,1,2,7,5,4,9,6,8]

2. 执行 "间隔序列=2"的步骤

A. 第一次查找 找到元素 0,1,7,4,6,所以原理还是和上面一样,0和1不需要移动 7和4及6调换位置,因此现在的顺序变为 0,1,4,6,7

B. 第二次查找 找到元素 3,2,5,9,8 ,所以顺序变为 2,3,5,8,9

执行完上面的步骤后,正确的顺序为 [0,2,1,3,4,5,6,8,7,9] 如上图(间隔序列=2)

3. 执行 "间隔序列=1"的步骤;

数组的顺序就变为 [0,1,2,3,4,5,6,7,8,9].如上图(间隔序列=1)

JS代码如下:

function CArray(numElements,gaps) {
this.dataStore = [];
this.pos = 0;
this.numElements = numElements;
this.gaps = gaps;
this.insert = insert;
this.toString = toString;
this.clear = clear;
this.shellSort = shellSort;
for(var i = 0; i < numElements.length; i++) {
this.dataStore[i] = numElements[i];
}
}
function clear() {
for(var i = 0; i < this.dataStore.length; i++) {
this.dataStore[i] = 0;
}
}
function insert(element) {
this.dataStore[this.pos++] = element;
}
function toString() {
var restr = "";
for(var i = 0; i < this.dataStore.length; i++) {
restr += this.dataStore[i] + " ";
if(i > 0 && i % 10 == 0) {
restr+= "\n";
}
}
return restr;
} function shellSort() {
for(var g = 0; g < this.gaps.length; ++g) {
for(var i = this.gaps[g]; i < this.dataStore.length; ++i) {
var temp = this.dataStore[i];
for(var j = i; j >= this.gaps[g] && this.dataStore[j - this.gaps[g]] > temp; j -= this.gaps[g]) {
this.dataStore[j] = this.dataStore[j - this.gaps[g]];
}
this.dataStore[j] = temp;
}
}
}
// 希尔排序测试代码
var numElements = [0,9,1,8,7,6,2,3,5,4];
var gaps = [3,2,1];
var myNums = new CArray(numElements,gaps);
myNums.shellSort();
console.log(myNums.toString());

二:快速排序

快速排序是处理大数据集最快的排序算法之一。它是一种分而治之的算法,通过递归的方式将数据依次分解为包含较小元素和较大的元素的不同子序列。该算法不断重复这个步骤直到所有数据都是有序的。

这个算法首先要在列表中选择一个元素来作为基准值,数据排序围绕基准值进行,将列表中小于基准值的元素移动到数组的左边,将大于基准值的元素移动到数组的右边,如下图所示:

基本原理是:

  1. 选择一个基准元素,将列表分割成2个子序列。基准元素的选择可以有3种方式,可以选择第一个元素作为基准元素,也可以把中间的值作为基准元素,还可以把最后一个元素作为基准的元素。
  2. 对列表重新排序,将所有小于基准值的元素放在基准值的前面,所有大于基准值的元素放在基准值的后面。
  3. 分别对较小元素的子序列和较大元素的子序列的重复步骤1和2.

下面是JS的代码如下:

// 快速排序
function qSort(list) {
if(list.length == 0) {
return [];
}
// 存储小于基准值的值
var left = [];
// 存储大于基准值的值
var right = [];
var pivot = list[0];
for(var i = 1; i < list.length; i++) {
if(list[i] < pivot) {
left.push(list[i]);
}else {
right.push(list[i])
}
}
return qSort(left).concat(pivot,qSort(right));
}
// 快速排序测试代码
var numElements = [44,75,23,43,55,12,64,77,33];
var list = qSort(numElements);
console.log(list); // [12, 23, 33, 43, 44, 55, 64, 75, 77]

javascript数据结构与算法--高级排序算法的更多相关文章

  1. javascript数据结构与算法--高级排序算法(快速排序法,希尔排序法)

    javascript数据结构与算法--高级排序算法(快速排序法,希尔排序法) 一.快速排序算法 /* * 这个函数首先检查数组的长度是否为0.如果是,那么这个数组就不需要任何排序,函数直接返回. * ...

  2. 【高级排序算法】2、归并排序法的实现-Merge Sort

    简单记录 - bobo老师的玩转算法系列–玩转算法 -高级排序算法 Merge Sort 归并排序 Java实现归并排序 SortTestHelper 排序测试辅助类 package algo; im ...

  3. 【高级排序算法】1、归并排序法 - Merge Sort

    归并排序法 - Merge Sort 文章目录 归并排序法 - Merge Sort nlogn 比 n^2 快多少? 归并排序设计思想 时间.空间复杂度 归并排序图解 归并排序描述 归并排序小结 参 ...

  4. JS中算法之排序算法

    1.基本排序算法 1.1.冒泡排序 它是最慢的排序算法之一. 1.不断比较相邻的两个元素,如果前一个比后一个大,则交换位置. 2.当比较完第一轮的时候最后一个元素应该是最大的一个. 3.按照步骤一的方 ...

  5. javascript高级排序算法之快速排序(快排)

    javascript高级排序算法之快速排序(快排)我们之前讨论了javascript基本排序算法 冒泡排序 选择排序 插入排序 简单复习: 冒泡排序: 比较相邻的两个元素,如果前一个比后一个大,则交换 ...

  6. javascript数据结构与算法--基本排序算法(冒泡、选择、排序)及效率比较

    javascript数据结构与算法--基本排序算法(冒泡.选择.排序)及效率比较 一.数组测试平台. javascript数据结构与算法--基本排序(封装基本数组的操作),封装常规数组操作的函数,比如 ...

  7. 在Object-C中学习数据结构与算法之排序算法

    笔者在学习数据结构与算法时,尝试着将排序算法以动画的形式呈现出来更加方便理解记忆,本文配合Demo 在Object-C中学习数据结构与算法之排序算法阅读更佳. 目录 选择排序 冒泡排序 插入排序 快速 ...

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

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

  9. 数据结构Java版之排序算法(二)

    排序按时间复杂度和空间复杂度可分为 低级排序 和 高级排序 算法两种.下面将对排序算法进行讲解,以及样例的展示. 低级排序:冒泡排序.选择排序.插入排序. 冒泡排序: 核心思想,小的数往前移.假设最小 ...

随机推荐

  1. [WPF系列]-高级部分 Shadowed TextBox

    Download Solution ShadowedTextBoxExample.zip (70.3 KB) Usage <local:ShadowedTextBox Label="F ...

  2. java设计模式之中介者模式

    中介者模式 用一个中介对象来封装一系列的对象交互.中介者使各个对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互. 中介者模式UML图 中介者模式代码 package com ...

  3. HTML ------ 关于表单 Form

    Form(表单)主要用于采集和提交用户输入的信息,是页面与WEB服务器交互过程中 最重要的信息来源. 掌握表单(Form)有以下几个要点: 重要form属性 form常用控件 form提交方式 § 重 ...

  4. 360:且用且珍惜!解决虚拟机linux启动缓慢以及ssh端卡顿的问题!

    优化软件以及杀毒软件想必大家都是用过的,小编自用的第一台电脑自带安装的是金山毒霸,随着时间的偏移渐渐用过小红伞,卡巴斯基,优化大师,鲁大师到后来的360优化杀毒套装,优化软件给大家带来了方便,尤其是上 ...

  5. suid sgid sbit chattr lsattr

    suid 一般用于二进制可执行文件,suid代表当用户执行此二进制文件时,暂时具有此文件所有者的权限 chmod 4xxx binfile sgid 一般用于目录,sgid代表当其他用户在此目录下创建 ...

  6. ASP.net 实现禁止用户重复登录

    本文先为大家介绍如何利用缓存Cache方便地实现此功能. Cache与Session这二个状态对像的其中有一个不同之处,Cache是一个全局对象,作用的范围是整个应用程序,所有用户:而Session是 ...

  7. tfs2012迁移,只用到源代码管理

    背景:在虚拟机里面安装的tfs,后来发觉C盘空间太少了,运行卡,准备重新配置一台虚拟机当做tfs服务器.安装相同版本的tfs.数据库(至少比原来的版本一样或者更高版本,要不附加不了数据库). 1.确保 ...

  8. iis6403、 iis7403.14

    iis6ie显示:您无权查看该网页,http错误403-禁止访问.chorme显示:Directory Listing Denied iis7显示:403.14-Forbidden Web 服务器被配 ...

  9. jquery.lazyload 实现图片延迟加载jquery插件

    看到了淘宝产品介绍中,图片是在下拉滚动条时加载,这是一个很不错的用户体验.减少了页面加载的时间了,也减轻了服务器的压力,就查了下用JQuery..   什么是ImageLazyLoad技术 在页面上图 ...

  10. Web 开发中很实用的10个效果

    在工作中,我们可能会用到各种交互效果.而这些效果在平常翻看文章的时候碰到很多,但是一时半会又想不起来在哪,所以养成知识整理的习惯是很有必要的.这篇文章给大家推荐10个在 Web 开发中很有用的效果,记 ...