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);
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java标识符是什么_Java 标识符「建议收藏」

    java标识符是什么_Java 标识符「建议收藏」什么是标识符标识符就是程序员在编写Java程序时,自定义的一些名字。例如第一个Java程序里关键字class后跟的HelloWorld,就是我们自定义的类名。类名就属于标识符的一种。标识符除了应用在类名上,还可以用在接口、变量、方法名、包名上。(要求同学们先记住,以后会详细见到这些)。标识符命名规则标识符由字母、下划线、美元符或数字组成标识符不能以数字开头,不能是关键字标识符严格区分大…

    2022年7月9日
    21
  • linux 抓包命令tcpdump

    linux 抓包命令tcpdump一、概述顾名思义,tcpdump可以将网络中传送的数据包的“头”完全截获下来提供分析。它支持针对网络层、协议、主机、网络或者端口的过滤,并提供and\or\not等逻辑语句来帮助你去掉无用的信息。二、选项介绍-a 将网络地址和广播地址转变成名字; -b 在数据-链路层上选择协议,包括ip、arp、rarp、ipx都是这一层的。 -c 指定要监听的数据包数量,在收

    2022年8月22日
    9
  • CTK框架介绍

    CTK框架介绍转(http://blog.csdn.net/xinqidian2015/article/details/50537325)CTK插件框架可以简单的描述为C++的动态组件系统DesignCTK插件框架的设计有很大的灵感来自OSGi并且使得应用程序由许多不同的组件组合成一个可扩展模型。这个模型允许通过那些组件间共享对象的服务通信。框架的分层模型被展示在图片1中包括:P

    2022年6月5日
    230
  • Delphi中强制IdHTTP使用HTTP1.1(转)

    Delphi中强制IdHTTP使用HTTP1.1(转)Delphi中强制IdHTTP使用HTTP1.1(转)标签:delphiwindows工具server2011-07-1807:46952人阅读评论(0)收藏举报分类:DelphiIdHttp控件(29)前两天帮人写程序用IdHTTP控件往一网站发包如下:Delphi代码IdHTTP1.Request.Connection:=’Keep-A…

    2022年7月15日
    13
  • pycharm卸载了环境变量还在怎么办_pycharm使用教程

    pycharm卸载了环境变量还在怎么办_pycharm使用教程因为之前的pycharm是社区版的,有些功能不全,所以需要重装专业版重装pycharm最大的顾虑就是之前的库能否保留以及能否删除干净1.之前的库包卸载之前找到我之前的库包所用编译器,记下路径就行注意:因为python跟pycharm是单独存在的,所以删除的pycharm并没有影响python里安装的库包2.删除正版软件删除是最简单的,找到文件所在位置,直接卸载就行这里注意两个红色箭头要全选,然后等待卸载结束就行。3.重新安装下载链接:http://www.jetbrains.com/

    2022年8月27日
    7
  • 抖音设备激活破解方法

    抖音设备激活破解方法,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月14日
    129

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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