JS排序算法之归并排序
归并排序是一种效率很高的算法,是一种把数组不断切分成小数组,排序后组合的算法。
1 var group= [1,9,3,5,0,4,2,8]; 2 3 4 function mergeSort(list) { 5 var length = list.length; 6 if(length==1){ //结束条件 7 return list; 8 } 9 var mid = Math.floor(length/2); 10 var left = list.slice(0,mid); 11 var right = list.slice(mid,length); 12 return merge(mergeSort(left),mergeSort(right));//递归 13 }; 14 15 function merge(left,right) { 16 var result = []; 17 var nl = 0; 18 var nr =0; 19 while(nl<left.length && nr<right.length){ 20 if(left[nl]<right[nr]){//按从小到大的顺序排列新的组合数组 21 result.push(left[nl++]);//扔进去之后迭代 22 }else{ 23 result.push(right[nr++]); 24 } 25 26 } 27 while(nl<left.length){//剩下的一股脑儿扔进去。 28 result.push(left[nl++]); 29 30 } 31 while(nr<right.length){ 32 result.push(right[nr++]); 33 34 } 35 36 return result; 37 } 38 39 40 41 mergeSort(group);
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)