JavaScript版几种常见排序算法分享

说明

·  每个浏览器测试得出的数据会不一样。比如我用chrome 测试 一般快速排序都会最快,IE 则根据数组长度有可能希尔最快。

·  不要用太大数据去测试冒泡排序(浏览器崩溃了我不管)

个人理解

·  冒泡排序:最简单,也最慢,貌似长度小于7最优

·  插入排序: 比冒泡快,比快速排序和希尔排序慢,较小数据有优势

·  快速排序:这是一个非常快的排序方式,V8的sort方法就使用快速排序和插入排序的结合

·  希尔排序:在非chrome下数组长度小于1000,希尔排序比快速更快

·  系统方法:在forfox下系统的这个方法非常快
 


  1.  // ---------- 一些排序算法  
  2.     // js 利用sort进行排序  
  3.      systemSort:function(array){  
  4.         return array.sort(function(a, b){  
  5.             return a - b;  
  6.         });  
  7.     },  
  8.     // 冒泡排序  
  9.     bubbleSort:function(array){  
  10.         var i = 0, len = array.length,  
  11.             j, d;  
  12.         for(; i<len; i++){  
  13.             for(j=0; j<len; j++){  
  14.                 if(array[i] < array[j]){  
  15.                     d = array[j];  
  16.                     array[j] = array[i];  
  17.                     array[i] = d;  
  18.                 }  
  19.             }  
  20.         }  
  21.         return array;  
  22.     },  
  23.     // 快速排序  
  24.     quickSort:function(array){  
  25.         //var array = [8,4,6,2,7,9,3,5,74,5];  
  26.         //var array =
     [0,1,2,44,4,324,5,65,6,6,34,4,5,6,2,43,5,6,62,43,5,1,4,51,56,76,7,7,2,1,45,4,6,7];  
  27.         var i = 0;  
  28.         var j = array.length - 1;  
  29.         var Sort = function(i, j){  
  30.               
  31.             // 结束条件  
  32.             if(i == j ){ return };  
  33.               
  34.             var key = array[i];  
  35.             var tempi = i; // 记录开始位置  
  36.             var tempj = j; // 记录结束位置  
  37.               
  38.             while(j > i){  
  39.                 // j <<-------------- 向前查找  
  40.                 if(array[j] >= key){  
  41.                     j--;  
  42.                 }else{  
  43.                     array[i] = array[j]  
  44.                     //i++ ------------>>向后查找  
  45.                     while(j > ++i){  
  46.                         if(array[i] > key){  
  47.                             array[j] = array[i];  
  48.                             break;  
  49.                         }  
  50.                     }  
  51.                 }  
  52.             }  
  53.               
  54.             // 如果第一个取出的 key 是最小的数  
  55.             if(tempi == i){  
  56.                 Sort(++i, tempj);  
  57.                 return ;  
  58.             }  
  59.               
  60.             // 最后一个空位留给 key  
  61.             array[i] = key;  
  62.               
  63.             // 递归  
  64.             Sort(tempi, i);  
  65.             Sort(j, tempj);  
  66.         }  
  67.           
  68.         Sort(i, j);  
  69.           
  70.         return array;  
  71.     },  
  72.       
  73.     // 插入排序  
  74.     insertSort:function(array){  
  75.           
  76.         // http://baike.baidu.com/image/d57e99942da24e5dd21b7080  
  77.         // http://baike.baidu.com/view/396887.htm  
  78.         //var array = 
    [0,1,2,44,4,324,5,65,6,6,34,4,5,6,2,43,5,6,62,43,5,1,4,51,56,76,7,7,2,1,45,4,6,7];  
  79.           
  80.         var i = 1, j, temp, key,  
  81.             len = array.length;  
  82.           
  83.         for(; i < len; i++){  
  84.               
  85.             temp = j = i;  
  86.             key = array[j];  
  87.               
  88.             while(--j > -1){  
  89.                 if(array[j] > key){  
  90.                     array[j+1] = array[j];  
  91.                 }else{  
  92.                     break;  
  93.                 }  
  94.             }  
  95.               
  96.             array[j+1] = key;  
  97.         }  
  98.           
  99.         return array;  
  100.     },  
  101.       
  102.     // 希尔排序  
  103.     //Jun.array.shellSort(Jun.array.df(10000));  
  104.     shellSort:function(array){  
  105.  
  106.         // http://zh.wikipedia.org/zh/%E5%B8%8C%E5%B0%94%E6%8E%92%E5%BA%8F  
  107.         // var array = [13,14,94,33,82,25,59,94,65,23,45,27,73,25,39,10];  
  108.           
  109.         var tempArr = [1750, 701, 301, 132, 57, 23, 10, 4, 1];   
  110. // reverse() 在维基上看到这个最优的步长 较小数组  
  111.         //var tempArr = [1031612713, 217378076, 45806244,   
  112. 9651787, 2034035, 428481, 90358, 19001, 4025, 836, 182, 34, 9, 1]  
  113. //针对大数组的步长选择  
  114.         var i = 0;  
  115.         var tempArrtempArrLength = tempArr.length;  
  116.         var len = array.length;  
  117.         var len2 =  parseInt(len/2);  
  118.           
  119.         for(;i < tempArrLength; i++){  
  120.             if(tempArr[i] > len2){  
  121.                 continue;  
  122.             }  
  123.               
  124.             tempSort(tempArr[i]);  
  125.         }  
  126.  
  127.         // 排序一个步长  
  128.         function tempSort(temp){  
  129.               
  130.             //console.log(temp) 使用的步长统计  
  131.               
  132.             var i = 0, j = 0, f, tem, key;  
  133.             var tempLen = len%temp > 0 ?  parseInt(len/temp) + 1 : len/temp;   
  134.               
  135.               
  136.             for(;i < temp; i++){// 依次循环列  
  137.  
  138.                 for(j=1;/*j < tempLen && */temp * j + i < len; j++){
    //依次循环每列的每行  
  139.                     tem = f = temp * j + i;  
  140.                     key = array[f];  
  141.  
  142.                     while((tem-=temp) >= 0){  
  143. // 依次向上查找  
  144.                         if(array[tem] > key){  
  145.                             array[tem+temp] = array[tem];  
  146.                         }else{  
  147.                             break;  
  148.                         }  
  149.                     }  
  150.                       
  151.                     array[tem + temp ] = key;  
  152.                       
  153.                 }  
  154.             }  
  155.               
  156.         }  
  157.           
  158.         return array;  
  159.           
  160.     } 

原文链接:http://www.cnblogs.com/idche/archive/2011/02/16/1956397.html

【编辑推荐】

  1. 10个令人惊奇的HTML5和JavaScript效果
  2. JavaScript对象及继承教程之内置对象
  3. JavaScript内存回收机制深入解读
  4. JavaScript初学者应注意的七个细节
  5. 写了10年Javascript未必全了解的连续赋值运算

【责任编辑:陈贻新 TEL:(010)68476606】

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索数组
, 分数步长法
, 排序
, 希尔排序
, function
, array
, var
, 快速
, javascript冒泡排序
, 冒泡排序和sort
, JavaScript快速排序
, js快速排序
, js冒泡排序
JS插入排序
javascript排序算法、常见排序算法、常见的排序算法、java常见排序算法、几种常见的排序算法,以便于您获取更多的相关知识。

时间: 2024-12-03 12:03:57

JavaScript版几种常见排序算法分享的相关文章

JavaScript中几种常见排序算法小结_javascript技巧

说明 写这个主要是为了锻炼自己,并无实际意义. 每个浏览器测试得出的数据会不一样.比如我用chrome 测试 一般快速排序都会最快,IE 则根据数组长度有可能希尔最快. 不要用太大数据去测试冒泡排序(浏览器崩溃了我不管) 如果有兴趣可以 下载测试页面 个人理解 冒泡排序:最简单,也最慢,貌似长度小于7最优 插入排序: 比冒泡快,比快速排序和希尔排序慢,较小数据有优势 快速排序:这是一个非常快的排序方式,V8的sort方法就使用快速排序和插入排序的结合 希尔排序:在非chrome下数组长度小于10

Java实现几种常见排序算法代码_java

稳定度(稳定性)一个排序算法是稳定的,就是当有两个相等记录的关键字R和S,且在原本的列表中R出现在S之前,在排序过的列表中R也将会是在S之前. 排序算法分类 常见的有插入(插入排序/希尔排序).交换(冒泡排序/快速排序).选择(选择排序).合并(归并排序)等. 一.插入排序 插入排序(Insertion Sort),它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入.插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),

Javascript中的常见排序算法_javascript技巧

具体代码及比较如下所示: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  <html xmlns="http://www.w3.org/1999/xhtml" lang="gb2312">

视觉直观感受 7 种常用排序算法

10月14日发布<统计世界的十大算法>后,很多朋友在后台询问,哪里有"视觉直观感受 7 种常用排序算法",今天分享给大家,感谢todayx.org. 1. 快速排序 介绍: 快速排序是由东尼·霍尔所发展的一种排序算法.在平均状况下,排序 n 个项目要Ο(n log n)次比较.在最坏状况下则需要Ο(n2)次比较,但这种状况并不常见.事实上,快速排序通常明显比其他Ο(n log n) 算法更快,因为它的内部循环(inner loop)可以在大部分的架构上很有效率地被实现出来,

php实现的常见排序算法汇总_php技巧

本文汇总了常见的php排序算法,在进行算法设计的时候有不错的借鉴价值.现分享给大家供参考之用.具体如下: 一.插入排序 用文字简单的描述,比如说$arr = array(4,2,4,6,3,6,1,7,9); 这样的一组数字进行顺序排序: 那么,首先,拿数组的第二个元素和第一元素比较,假如第一个元素大于第二元素,那么就让两者位置互换,接下来,拿数组的第三个元素,分别和第二个,第一个元素比较,假如第三个元素小,那么就互换.依次类推.这就是插入排序,它的时间频度是:1+2+...+(n-1)=(n^

几种经典排序算法的JS实现方法_基础知识

一.冒泡排序 function BubbleSort(array) { var length = array.length; for (var i = length - 1; i > 0; i--) { //用于缩小范围 for (var j = 0; j < i; j++) { //在范围内进行冒泡,在此范围内最大的一个将冒到最后面 if (array[j] > array[j+1]) { var temp = array[j]; array[j] = array[j+1]; arra

关于c++几种简单排序算法的比较次数和移动次数的问题

问题描述 关于c++几种简单排序算法的比较次数和移动次数的问题 排序结果没有问题,可是比较次数和移动次数的计数结果不对.求高人指点. #include<iostream> using namespace std; class Sort { private: int *r; int n; // the number of elements of array int MoveNum; int CompNum; public: void insert(); void bubble(); int ge

PHP 实现四种基本排序算法

PHP 实现四种基本排序算法 许多人都说算法是程序的核心,算法的好坏决定了程序的质量.作为一个初级phper,虽然很少接触到算法方面的东西.但是对于基本的排序算法还是应该掌握的,它是程序开发的必备工具.这里介绍冒泡排序,插入排序,选择排序,快速排序四种基本算法,分析一下算法的思路. (题图来自:robinhoodsplayground.com) 前提:分别用冒泡排序法,快速排序法,选择排序法,插入排序法将下面数组中的值按照从小到大的顺序进行排序.  $arr(1,43,54,62,21,66,3

php四种基础排序算法的运行时间比较

/**  * php四种基础排序算法的运行时间比较  * @authors Jesse (jesse152@163.com)  * @date    2016-08-11 07:12:14  */ //冒泡排序法 function bubbleSort($array){     $temp = 0;     for($i = 0;$i < count($array) -1;$i++){         for($j = 0;$j < count($array) - 1 -$i;$j++){