码迷,mamicode.com
首页 > 其他好文 > 详细

[Algorithm] 46. Permutations

时间:2019-12-09 01:20:14      阅读:72      评论:0      收藏:0      [点我收藏+]

标签:from   log   Fix   span   concat   ack   one   UNC   rom   

Given a collection of distinct integers, return all possible permutations.

Example:

Input: [1,2,3]
Output:
[
  [1,2,3],
  [1,3,2],
  [2,1,3],
  [2,3,1],
  [3,1,2],
  [3,2,1]
]

 

The idea is using recursive approach, we can define a recursive function

helper(prefix, suffix, result)

Where the prefix is: for example

[1]

suffix:

[2, 3]

So every time, we take one value from suffix, put into prefix.

 

The stop logic is that when suffix length is zero, then we push the prefix into result.

if (sfx.length === 0) {
     result.push(pfx);
}

 

/**
 * @param {number[]} nums
 * @return {number[][]}
 */
var permute = function(nums) {
    function helper (pfx, sfx, result) {
        if (sfx.length === 0) {
            result.push(pfx);
        } else {
            const len = sfx.length;
            for (let i = 0; i < len; i++) {
                helper(
                    pfx.concat(sfx[i]), 
                    sfx.slice(0, i).concat(sfx.slice(i+1, sfx[len])), 
                    result
                );
            }
        }
        
        return result;
    }
    
    return helper([], nums, []);
};

permute([1,2,3])

/*

[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

*/

 

[], [1,2,3]

[1], [2,3]

[1, 2], [3], [] | [1, 3], [2] 

---> [1,2,3] | [1,2,3]

[2], [1, 3]
[2, 1], [3] | [2,3] [1]

--> [2,1,3] | [2,3,1]

[3], [1,2]
[3,1][2] | [3,2], [1]

--> [3,1,2] | [3,2,1]

 

[Algorithm] 46. Permutations

标签:from   log   Fix   span   concat   ack   one   UNC   rom   

原文地址:https://www.cnblogs.com/Answer1215/p/12008553.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!