js数组排序—自定义快速排序

js数组排序—自定义快速排序数组自带的sort方法 vararr=[3,4,2,1]; arr.sort(); console.log(arr);进行递增排序(4)[1,2,3,4]sort方法可以接收一个参数,用来自定义排序规则 arr.sort(function(val1,val2){ //returnval1-val2;默认 returnval2-…

大家好,又见面了,我是你们的朋友全栈君。

js数组自带的sort方法

		var arr = [3, 4, 2, 1];
		arr.sort();
		console.log(arr);

默认进行递增排序

(4) [1, 2, 3, 4]

sort方法可以接收一个参数,用来自定义排序规则

		arr.sort(function(val1, val2){ 
   
			//return val1 - val2; 默认
			return val2 - val1;//倒序。根据结果大于0、小于0、等于零做判断
		});

如果数组元素为非数字类型,必须要手动指定排序规则,否则可能会产生诡异的结果。
比如,两个字符串相减结果为NaN,这回导致排序不生效。

当元素为对象时,例

		var arr = [{ 
   "a":1},{ 
   "a":311},{ 
   "a":2}];
		arr.sort(function(val1, val2){ 
   
			return val2.a - val1.a;
		});
		console.log(arr);

经查询资料得知,sort方法竟然是用的冒泡排序。。。换一个效率高些的吧。

快速排序

Array.prototype.sortq = function(_compare){ 

var _this = this;
if(this.length == 0)
return;			
var compare = _compare || function(val1, val2){ 

return val1 - val2 > 0 ? false : true;
};
function quickSort(src){ 

_quickSort(src, 0, src.length - 1);
}
function _quickSort(src, left, right){ 

var key = src[left];
var keyIndex = left;
var i = left;
var j = right;
while(i < j){ 

while(i < j){ 

if(compare(_this[j], _this[keyIndex])){ 

src[keyIndex] = src[j];
src[j] = key;
keyIndex = j;
break;
}
j--;
}
while(i < j){ 

if(compare(_this[keyIndex], _this[i])){ 

src[keyIndex] = src[i];
src[i] = key;
keyIndex = i;
break;
}
i++;
}
}
if(left != right){ 

if(keyIndex != left)
_quickSort(src, left, keyIndex - 1);
if(keyIndex != right)
_quickSort(src, keyIndex + 1, right);
}	
}
quickSort(this);
}

测试一下效率

		var arr1 = new Array();
for(var i = 0; i < 1000000; i++)
arr1.push(Math.random());
var dat1 = new Date();
arr1.sort();
var dat2 = new Date();
console.log(dat2.getTime() - dat1.getTime());
var arr2 = new Array();
for(var i = 0; i < 1000000; i++)
arr2.push(Math.random());
var dat3 = new Date();
arr2.sortq();
var dat4 = new Date();
console.log(dat4.getTime() - dat3.getTime());

输出

7237
292

效率提升了20多倍。虽然还有更高效率的算法,不过这个也够用了。

2020年04月26日 补上对象数组排序

		var arr3 = new Array();
for(var i = 0; i < 40; i++){ 

arr3.push(
{ 

aa: Math.random()
}
);
}
arr3.sortq(function(val1, val2){ 

return val1.aa - val2.aa > 0 ? false : true;
});
console.log(arr3);
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/137617.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • FFMPEG入门[通俗易懂]

    FFMPEG入门[通俗易懂]本文转自 http://blog.csdn.net/leixiaohua1020/article/details/15811977

  • NULL与nullptr

    传统意义上来说,c++把NULL、0视为同一种东西,有些编译器将NULL定义为((void*)0),有些将其定义为0.c++不允许直接将void*隐式的转化为其他类型,但是如果NULL被定义为((void*)0),当编译char*p=NULL;NULL只好被定义为0。还有:void  func(int);void  func(char*);如果NULL被定义为0,func(NUL…

  • java大一期末试卷含答案

    java大一期末试卷含答案答案是自己写的,不敢保证全对若有不正之处,请多多谅解并欢迎指正。一、单项选择题1.公有类型常量定义(publicstaticfinal三个关键字的含义)。访问控制符public能被所有的类访问static静态的被static修饰的变量为类变量/静态变量。静态变量又称为类的成员变量,在类中是全局变量,可以被类中的所有方法调用。final最终的被final修饰的变量为常…

  • mysql一键部署脚本

    mysql一键部署脚本

  • spring ajax 长轮询,Ajax轮询和长轮询

    spring ajax 长轮询,Ajax轮询和长轮询缺点:Ajax轮询需要服务器有很快的处理速度与快速响应。longpoll需要很高的并发,体现在同时容纳请求的能力。一、轮询是在浏览器客户端实现的:如果从后端获取数据成功则停止请求。$(function(){varcode,status;functiongetResult(){varparams={code:code,operate:’什么操作TODO:’,};$.ajax({typ…

    2022年10月14日
  • Wireshark安装使用[通俗易懂]

    Wireshark工具下载下载解压默认安装即可然后选择你的网卡点击Start抓包即可

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号