这篇文章主要为大家详细介绍了 JS 快速排序的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
说明
时间复杂度指的是一个算法执行所耗费的时间 空间复杂度指运行完一个程序所需内存的大小 稳定指,如果 a=b,a 在 b 的前面,排序后 a 仍然在 b 的前面 不稳定指,如果 a=b,a 在 b 的前面,排序后可能会交换位置
--JS 快速排序 --
原理
从数组中选定一个基数,然后把数组中的每一项与此基数做比较,小的放入一个新数组,大的放入另外一个新数组。然后再采用这样的方法操作新数组。直到所有子集只剩下一个元素,排序完成。
时间复杂度,空间复杂度,稳定性
快速排序的写法
- var examplearr=[8,94,15,88,55,76,21,39];
- function fastsort(arr){
- if(arr.length<2){
- return arr;
- }
- var left=[];
- var right=[];
- var pivotIndex=Math.floor(arr.length/2);
- var pivot=arr.splice(pivotIndex,1)[0];
- for(i=0;i<arr.length;i++){
- if(arr[i]<pivot){
- left.push(arr[i]);
- }else{
- right.push(arr[i])
- }
- }
- return fastsort(left).concat([pivot],fastsort(right));
- }
- console.log(fastsort(examplearr));
解析
pivotIndex 是将数组的长度除 2 向下取整得到的一个数值,数组的长度是不断减半的,所以最后它的值为 0
pivot 是利用 splice 方法从数组里获取一个基数
来源: http://www.phperz.com/article/17/0516/334196.html