小编zaz*_*zou的帖子

通过Heap算法和神秘逗号进行排列

我花了一整天时间(最后)在周五的一个入学申请实践中围绕一个排列算法.Heap的算法对我来说似乎最简单和优雅.

这是一个例子:http://en.wikipedia.org/wiki/Heap%27s_algorithm

 function permutationArr(num) { 
    var str = num.toString();
    var arr = str.split('');
    var permutations = [];   
    function getPerm(arr,n){   
        var localArr = arr.slice(0);
        var i;
        var swap;
        var temp; 
        if(n==1){
            permutations.push(localArr.toString());
            return;
        }
        for(i=0;i<n;i++){
            getPerm(localArr,n-1);    
            swap = (n%2 ? i: 0);
            temp = localArr[swap];
            localArr[swap] = localArr[n-1];
            localArr[n-1] = temp;    
        }
    }    
    getPerm(arr,arr.length);
    console.log(permutations);
    return;    
}    
permutationArr(1234);     
Run Code Online (Sandbox Code Playgroud)

最终排列数组的日志如下:

 ["1,2,3,4", "1,3,2,4", "4,2,3,1", "4,3,2,1", "4,1,3,2", "4,3,1,2", "1,,3,4,2", "1,3,,4,2", "4,,3,1,2", "4,3,,1,2", "4,1,3,,2", "4,3,1,,2", "1,2,3,4,", "1,3,2,4,", "4,2,3,1,", "4,3,2,1,", "4,1,3,2,", "4,3,1,2,", "1,,3,4,2", …
Run Code Online (Sandbox Code Playgroud)

javascript algorithm combinations permutation

9
推荐指数
2
解决办法
6695
查看次数

标签 统计

algorithm ×1

combinations ×1

javascript ×1

permutation ×1