V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
mara1
V2EX  ›  程序员

大佬们,我这算非递归归并排序吗?

  •  
  •   mara1 · Jul 13, 2019 · 2012 views
    This topic created in 2482 days ago, the information mentioned may be changed or developed.
    function mergeSort(array){
        if(array.length==1){
            return array;
        }
        for(let len = 2;len/2<=array.length;len*=2){
            for(let start=0;start<array.length;start+=len){
                sort(start,len,array)
            }
        }
        return array;
    }
    function sort(start,len,arr){
        let middle = start+ len/2;
        let left = arr.slice(start,middle);
        let right = arr.slice(middle,start+len);
        let res = [];
        while(left.length>0 && right.length>0){
            if(left[0]<right[0]){
                res.push(left[0])
                left.shift();
            }else{
                res.push(right[0]);
                right.shift();
            }
        }
        let replace = res.concat(left).concat(right);
        arr.splice(start,len,...replace);
    }
    let a = [3,1,0,9,8,11,12,6,4,7]
    
    var result = mergeSort(a);
    console.log("arr:",result);
    
    3 replies    2019-07-13 23:21:40 +08:00
    guyeu
        1
    guyeu  
       Jul 13, 2019
    算。
    doing1
        2
    doing1  
       Jul 13, 2019
    是的
    singleQ
        3
    singleQ  
       Jul 13, 2019
    这个是快牌
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3778 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 35ms · UTC 10:31 · PVG 18:31 · LAX 03:31 · JFK 06:31
    ♥ Do have faith in what you're doing.