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)
上一篇 2022年5月5日 下午5:40
下一篇 2022年5月5日 下午5:40


相关推荐

  • 用c语言编写学生成绩管理系统(c语言学生成绩管理系统删除)

    一、课程设计题目①基本要求题目:矩阵乘法。②综合训练:学生成绩管理系统二、设计要求矩阵乘法:编写一个函数实现矩阵A(2行3列)与矩阵B相乘(3行2列),乘积放在C数组中。在主函数中输入相乘的两数组,并输出结果。学生成绩管理:(结构体数组、函数、指针、算法、流程结构及文件等的综合应用)程序说明:有N个学生,每个学生的数据包含学号(不重复)、姓名、三门课的成绩及平均成绩,试设计一学生成绩管理系统,…

    2022年4月11日
    166
  • 什么是递归,通过这篇文章,让你彻底搞懂递归

    什么是递归,通过这篇文章,让你彻底搞懂递归想了解更多数据结构以及算法题 可以关注微信公众号 数据结构和算法 每天一题为你精彩解答 也可以扫描下面的二维码关注啥叫递归聊递归之前先看一下什么叫递归 递归 就是在运行的过程中调用自己 构成递归需具备的条件 1 子问题须与原始问题为同样的事 且更为简单 2 不能无限制地调用本身 须有个出口 化简为非递归状况处理 递归语言例子我们用 2 个故事来阐述一下什么叫递归 1 从前有座山 山里有座庙 庙里有个老和尚 正在给小和尚讲故事呢 故事是什么呢 从前有座山 山里有座庙 庙里有个老和尚 正

    2025年6月22日
    6
  • vmware 15.5.7 激活码【中文破解版】

    (vmware 15.5.7 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/ide…

    2022年4月1日
    173
  • 你知道亚媒的来源么?「建议收藏」

    你知道亚媒的来源么?「建议收藏」亚媒是哪个的简称?亚洲媒体?亚太传媒?用亚媒进行名称的扩展时,你可以想出一堆的名字出来,什么亚太传媒,亚洲媒体,亚洲传媒等等。

    2026年1月27日
    3
  • Ubuntu 卸载 Docker

    Ubuntu 卸载 Docker1.卸载dockersudoapt-getautoremovedockerdocker-cedocker-enginedocker.iocontainerdrunc2.查看删除docker其他有没有没有卸载干净的包dpkg-l|grepdocker3.卸载相应的包sudoapt-getautoremovedocker-ce-*4.删除docker的相关配置&目录sudorm-rf/etc/systemd/system/docker.serv

    2022年5月7日
    61
  • 基于内容的图像检索技(CBIR)术相术介绍

    基于内容的图像检索技(CBIR)术相术介绍本文主要简单的介绍了基于内容的图像检索(CBIR:Content-BasedImageRetrieval)的相关技术,其是指根据图像对象的内容及上下文信息在大规模多媒体数据中检索所需信息。基于内容的图像检索技术通过近几十年的发展已经取得了丰硕的成果,文中对对图像检索的相关内容进行简单的分析,并对与图像检索相关的资料进行了简单的整理和收集。

    2025年10月23日
    8

发表回复

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

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