0

0

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

php中文网

php中文网

发布时间:2016-05-16 19:16:04

|

1146人浏览过

|

来源于php中文网

原创

具体代码及比较如下所示:

复制代码 代码如下:

html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
 
 
 常见排序算法 之 JavaScript版  
 
 
 
<script>  <br> Array.prototype.swap = function(i, j)  <br> {  <br> var temp = this[i];  <br> this[i] = this[j];  <br> this[j] = temp;  <br> }  <br> Array.prototype.bubbleSort = function()  <br> {  <br> for (var i = this.length - 1; i > 0; --i)  <br> {  <br> for (var j = 0; j < i; ++j)  <br> {  <br> if (this[j] > this[j + 1]) this.swap(j, j + 1);  <br> }  <br> }  <br> }  <br> Array.prototype.selectionSort = function()  <br> {  <br> for (var i = 0; i < this.length; ++i)  <br> {  <br> var index = i;  <br> for (var j = i + 1; j < this.length; ++j)  <br> {  <br> if (this[j] < this[index]) index = j;  <br> }  <br> this.swap(i, index);  <br> }  <br> }  <br> Array.prototype.insertionSort = function()  <br> {  <br> for (var i = 1; i < this.length; ++i)  <br> {  <br> var j = i, value = this[i];  <br> while (j > 0 && this[j - 1] > value)  <br> {  <br> this[j] = this[j - 1];  <br> --j;  <br> }  <br> this[j] = value;  <br> }  <br> }  <br> Array.prototype.shellSort = function()  <br> {  <br> for (var step = this.length >> 1; step > 0; step >>= 1)  <br> {  <br> for (var i = 0; i < step; ++i)  <br> {  <br> for (var j = i + step; j < this.length; j += step)  <br> {  <br> var k = j, value = this[j];  <br> while (k >= step && this[k - step] > value)  <br> {  <br> this[k] = this[k - step];  <br> k -= step;  <br> }  <br> this[k] = value;  <br> }  <br> }  <br> }  <br> }  <br> Array.prototype.quickSort = function(s, e)  <br> {  <br> if (s == null) s = 0;  <br> if (e == null) e = this.length - 1;  <br> if (s >= e) return;  <br> this.swap((s + e) >> 1, e);  <br> var index = s - 1;  <br> for (var i = s; i <= e; ++i)  <br> {  <br> if (this[i] <= this[e]) this.swap(i, ++index);  <br> }  <br> this.quickSort(s, index - 1);  <br> this.quickSort(index + 1, e);  <br> }  <br> Array.prototype.stackQuickSort = function()  <br> {  <br> var stack = [0, this.length - 1];  <br> while (stack.length > 0)  <br> {  <br> var e = stack.pop(), s = stack.pop();  <br> if (s >= e) continue;  <br> this.swap((s + e) >> 1, e);  <br> var index = s - 1;  <br> for (var i = s; i <= e; ++i)  <br> {  <br> if (this[i] <= this[e]) this.swap(i, ++index);  <br> }  <br> stack.push(s, index - 1, index + 1, e);  <br> }  <br> }  <br> Array.prototype.mergeSort = function(s, e, b)  <br> {  <br> if (s == null) s = 0;  <br> if (e == null) e = this.length - 1;  <br> if (b == null) b = new Array(this.length);  <br> if (s >= e) return;  <br> var m = (s + e) >> 1;  <br> this.mergeSort(s, m, b);  <br> this.mergeSort(m + 1, e, b);  <br> for (var i = s, j = s, k = m + 1; i <= e; ++i)  <br> {  <br> b[i] = this[(k > e || j <= m && this[j] < this[k]) ? j++ : k++];  <br> }  <br> for (var i = s; i <= e; ++i) this[i] = b[i];  <br> }  <br> Array.prototype.heapSort = function()  <br> {  <br> for (var i = 1; i < this.length; ++i)  <br> {  <br> for (var j = i, k = (j - 1) >> 1; k >= 0; j = k, k = (k - 1) >> 1)  <br> {  <br> if (this[k] >= this[j]) break;  <br> this.swap(j, k);  <br> }  <br> }  <br> for (var i = this.length - 1; i > 0; --i)  <br> {  <br> this.swap(0, i);  <br> for (var j = 0, k = (j + 1) << 1; k <= i; j = k, k = (k + 1) << 1)  <br> {  <br> if (k == i || this[k] < this[k - 1]) --k;  <br> if (this[k] <= this[j]) break;  <br> this.swap(j, k);  <br> }  <br> }  <br> }  <br> function generate()  <br> {  <br> var max = parseInt(txtMax.value), count = parseInt(txtCount.value);  <br> if (isNaN(max) || isNaN(count))  <br> {  <br> alert("个数和最大值必须是一个整数");  <br> return;  <br> }  <br> var array = [];  <br> for (var i = 0; i < count; ++i) array.push(Math.round(Math.random() * max));  <br> txtInput.value = array.join("\n");  <br> txtOutput.value = "";  <br> }  <br> function demo(type)  <br> {  <br> var array = txtInput.value == "" ? [] : txtInput.value.replace().split("\n");  <br> for (var i = 0; i < array.length; ++i) array[i] = parseInt(array[i]);  <br> var t1 = new Date();  <br> eval("array." + type + "Sort()");  <br> var t2 = new Date();  <br> lblTime.innerText = t2.valueOf() - t1.valueOf();  <br> txtOutput.value = array.join("\n");  <br> }  <br></script> 
 
 
 
 
  
  
  
 
 
  
 
 
 随机数个数

 
 最大随机数

 
 



 
 耗时(毫秒):



 
 

 
 

 
 

 
 

 
 

 
 

 
 

 
 

 
 
 
  
 
 
 
 

快速排序, 插入排序, 希尔排序, 冒泡排序, quickSort, insertSort, shellSort, bubbleSort, javascript排序
说明
写这个主要是为了锻炼自己,并无实际意义。
每个浏览器测试得出的数据会不一样。比如我用chrome 测试 一般快速排序都会最快,IE 则根据数组长度有可能希尔最快。
不要用太大数据去测试冒泡排序(浏览器崩溃了我不管)
如果有兴趣可以 下载测试页面

个人理解

冒泡排序:最简单,也最慢,貌似长度小于7最优
插入排序: 比冒泡快,比快速排序和希尔排序慢,较小数据有优势
快速排序:这是一个非常快的排序方式,V8的sort方法就使用快速排序和插入排序的结合
希尔排序:在非chrome下数组长度小于1000,希尔排序比快速更快
系统方法:在forfox下系统的这个方法非常快

算法源码

ithy
ithy

融合多种AI模型的AI搜索平台

下载
复制代码 代码如下:

// ---------- 一些排序算法
// js 利用sort进行排序
systemSort:function(array){
return array.sort(function(a, b){
return a - b;
});
},
// 冒泡排序
bubbleSort:function(array){
var i = 0, len = array.length,
j, d;
for(; ifor(j=0; jif(array[i] d = array[j];
array[j] = array[i];
array[i] = d;
}
}
}
return array;
},
// 快速排序
quickSort:function(array){
//var array = [8,4,6,2,7,9,3,5,74,5];
//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];
var i = 0;
var j = array.length - 1;
var Sort = function(i, j){
// 结束条件
if(i == j ){ return };
var key = array[i];
var stepi = i; // 记录开始位置
var stepj = j; // 记录结束位置
while(j > i){
// j if(array[j] >= key){
j--;
}else{
array[i] = array[j]
//i++ ------------>>向后查找
while(j > ++i){
if(array[i] > key){
array[j] = array[i];
break;
}
}
}
}
// 如果第一个取出的 key 是最小的数
if(stepi == i){
Sort(++i, stepj);
return ;
}
// 最后一个空位留给 key
array[i] = key;
// 递归
Sort(stepi, i);
Sort(j, stepj);
}
Sort(i, j);
return array;
},
// 插入排序
insertSort:function(array){
// http://baike.baidu.com/image/d57e99942da24e5dd21b7080
// http://baike.baidu.com/view/396887.htm
//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];
var i = 1, j, step, key,
len = array.length;
for(; i step = j = i;
key = array[j];
while(--j > -1){
if(array[j] > key){
array[j+1] = array[j];
}else{
break;
}
}
array[j+1] = key;
}
return array;
},
// 希尔排序
//Jun.array.shellSort(Jun.array.df(10000));
shellSort:function(array){
// http://zh.wikipedia.org/zh/%E5%B8%8C%E5%B0%94%E6%8E%92%E5%BA%8F
// var array = [13,14,94,33,82,25,59,94,65,23,45,27,73,25,39,10];
var stepArr = [1750, 701, 301, 132, 57, 23, 10, 4, 1]; // reverse() 在维基上看到这个最优的步长 较小数组
//var stepArr = [1031612713, 217378076, 45806244, 9651787, 2034035, 428481, 90358, 19001, 4025, 836, 182, 34, 9, 1]//针对大数组的步长选择
var i = 0;
var stepArrLength = stepArr.length;
var len = array.length;
var len2 = parseInt(len/2);
for(;i if(stepArr[i] > len2){
continue;
}
stepSort(stepArr[i]);
}
// 排序一个步长
function stepSort(step){
//console.log(step) 使用的步长统计
var i = 0, j = 0, f, tem, key;
var stepLen = len%step > 0 ? parseInt(len/step) + 1 : len/step;

for(;i for(j=1;/*j tem = f = step * j + i;
key = array[f];
while((tem-=step) >= 0){// 依次向上查找
if(array[tem] > key){
array[tem+step] = array[tem];
}else{
break;
}
}
array[tem + step ] = key;
}
}
}
return array;
}

测试代码打包下载

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

705

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

233

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

117

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

22

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

61

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

30

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

15

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

669

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

58

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C++教程
C++教程

共115课时 | 18.5万人学习

微信小程序开发之API篇
微信小程序开发之API篇

共15课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号