全排列

作者: 轰炸机上调鸡尾酒 | 来源:发表于2018-03-16 14:18 被阅读16次

    给定一个数字列表,返回其所有可能的排列。

    class Solution {
    public:
        /*
         * @param nums: A list of integers.
         * @return: A list of permutations.
         */
        vector<vector<int>> permute(vector<int> &nums) {
            // write your code here
            vector<vector<int>> result;
            sort(nums.begin(),nums.end());
            permuteRec( 0, nums, result);
            return result;
        }
        
        void permuteRec( int start, vector<int> nums, vector<vector<int>> &result ){
            if( start >= nums.size()){
                result.push_back(nums);
                return;
            }
            for( int i = start; i < nums.size(); i++ ){
                if( i > start && nums[i] == nums[start]) continue;
                swap( nums[start], nums[i] );
                permuteRec( start+1, nums, result);
            }
        }
    };
    
    

    相关文章

      网友评论

          本文标题:全排列

          本文链接:https://www.haomeiwen.com/subject/hcalqftx.html