JS骚操作之数组快速排序

栏目: 编程工具 · 发布时间: 5年前

内容简介:如果你想要对数组排序,可能会去百度去搜,于是有很多人教你用冒泡,什么二分插入排序、堆排序,如果不太懂其中的代码意思,很难看明白。来,今天我来教大家一个骚操作。我利用的就是JS数组的索引来排序的,大家都知道,索引就是从0开始,然后依次递增的。好了,废话少说,开始撸了。

JS骚操作之数组快速排序

如果你想要对数组排序,可能会去百度去搜,于是有很多人教你用冒泡,什么二分插入 排序 、堆排序,如果不太懂其中的代码意思,很难看明白。来,今天我来教大家一个骚操作。

我利用的就是JS数组的索引来排序的,大家都知道,索引就是从0开始,然后依次递增的。好了,废话少说,开始撸了。

我们来上完整的代码:

var arr = [1,4,2,5,21,3,44,12];//要排序的数组。

var res = [];//要返回的排序后的数组。

var arr1 = [];//中间用到的过渡数组

arr.forEach(a=>{ arr1[a] = 1; });

arr1.forEach((r,index)=>{

    if(r === 1){
         res.push(index);//通过push默认是是升序,如果想降序可以采用unshift方法,或者在最后将数组反转一下即可。
    }
})

console.log(res);

arr.forEach(a=>{

//这一步很关键,我们把要排序的数组的每一项当作了中间过渡数组的索引,并赋值为1(这里不一定要是1,给一个特定的值就行)

arr1[a] = 1;

});

这时候arr1 的结果为: [empty, 1, 1, 1, 1, empty × 7, 1, empty × 8, 1, empty × 22, 1, empty × 10, 1]

这时候中间过渡数组arr1就有数据了,但是这个数组中有很多undefined,这时候我们再做最后的排除就好了。

写在最后:有人可能会提出来,如果数组中有重复项,那这种排序是不是不行了,当然可以, 做下处理,把重复的先拿到,重复了几次,然后在最后的结果数组中通过splice(index,0,item);对数组进行插入操作即可。

JS骚操作之数组快速排序

技术总结:

  1. 这个就是巧用了数组的索引,默认就是一个从小到大的排序的特性。这种方法简单易懂。
  2. 数组的基本方法的使用,像forEach push unshift reverse splice(这个splice可以做删除,插入,修改) 等。

以上所述就是小编给大家介绍的《JS骚操作之数组快速排序》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

程序员面试金典(第5版)

程序员面试金典(第5版)

[美] Gayle Laakmann McDowell / 李琳骁、漆 犇 / 人民邮电出版社 / 2013-11 / 59.00

本书是原谷歌资深面试官的经验之作,层层紧扣程序员面试的每一个环节,全面而详尽地介绍了程序员应当如何应对面试,才能在面试中脱颖而出。第1~7 章主要涉及面试流程解析、面试官的幕后决策及可能提出的问题、面试前的准备工作、对面试结果的处理等内容;第8~9 章从数据结构、概念与算法、知识类问题和附加面试题4 个方面,为读者呈现了出自微软、苹果、谷歌等多家知名公司的150 道编程面试题,并针对每一道面试题目......一起来看看 《程序员面试金典(第5版)》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

URL 编码/解码
URL 编码/解码

URL 编码/解码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具