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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • spring boot整合shiro_Spring框架介绍及使用

    spring boot整合shiro_Spring框架介绍及使用目录1、Shiro简介1.1、Shiro是什么?1.2、有哪些功能?1.3、Shiro架构(外部)2、快速入门(QuickStartShiro)2.1、项目结构2.2、导入shiro依赖,这是我的pom所有依赖。(pom.xml)2.3、相关配置文件(1)log4j.properties——官网(2)shiro.ini——官网(3)启动类Quickstart——官网3、SpringBoot集成Shiro框架3.1SpringBoot整合Shir…

    2025年10月7日
    5
  • charles(2)MAC Charles关闭后无法上网

    charles(2)MAC Charles关闭后无法上网前言charles关闭后,发现网页突然打开了,那大概率是设置了代理,但明明已经关闭了charles,这是由于mac网络偏好设置中,使用的是手动代理,将其改为自动即可解决方法1打开网络偏好设置,

    2022年7月28日
    47
  • 七个合法学习黑客技术的网站,让你从萌新成为大佬「建议收藏」

    合法的学习网站,以下这些网站,虽说不上全方位的满足你的需求,但是大部分也都能。

    2022年4月15日
    173
  • 数据结构教程 视频_神谷哲史男巫教程视频

    数据结构教程 视频_神谷哲史男巫教程视频史上最全的数据结构视频教程打包下载地址本文出自出自我是码农,转载请注明出处,谢谢!以下数据结构视频教程是我多年收集的,因为在百度网盘上分享整个教程很快就会被delete,所以我只好花费大量功夫对单个视频进行一个一个的分享,这样才能长时间保留下来,为了学习,麻烦些也值得了!现在毫无保留的免费共享给大家,与君共勉!个人认为数据结构这门课程比较难,看视频学习是最好的方式。当年我就是看了多个视频,然…

    2022年10月12日
    2
  • YUV和RGB的相互转换实验

    YUV和RGB的相互转换实验1、彩色空间转换基本原理1)彩色空间转换公式:为了实现格式转换,我们首先要明确待转换格式和目标格式的特点和相互转换关系,这是编程实现转换的核心。对于RGB转YUV的过程,我们要首先拿到RGB文件的数据,再通过上图的YUV计算公式对其做运算,得到YUV数据,从而实现转换。而对于YUV转RGB则要首先获得YUV数据,用第二组RGB公式计算得到RGB数据。在本实验中,转换公式如下。…

    2022年7月16日
    14
  • cmap用法,很详细(转)

    http://hi.baidu.com/wei83523408/blog/item/878ebd3b8898d5e115cecb2b.html一、Map的基本知识  映射(Map),又称为字典(Dictionary),是由关键字(Key)及其对应的元素值(Value)所组成的元素单元(Element)的表单式集合。通常,对于Map而言,使用给定的Key,可以迅速地从

    2022年4月3日
    213

发表回复

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

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