zoukankan      html  css  js  c++  java
  • LeetCode

    46. Permutations 

    Problem's Link

     ----------------------------------------------------------------------------

    Mean: 

    给定一个数组,求这个数组的全排列.

    analyse:

    方法1:调用自带函数next_permutation(_BIter,_BIter)

    方法2:自己手写一个permutation函数,很简单.

    Time complexity: O(N)

     

    view code

    #include <bits/stdc++.h>
    using namespace std;

    // way 1: use system's function:next_permutation(iter* begin,iter* end);
    //class Solution
    //{
    //public:
    //    vector<vector<int>> permute(vector<int>& nums)
    //    {
    //        vector<vector<int>> res;
    //        sort(nums.begin(),nums.end());
    //        res.push_back(nums);
    //        while(next_permutation(nums.begin(),nums.end()))
    //            res.push_back(nums);
    //        return res;
    //    }
    //};

    class Solution
    {
    public:
       vector<vector<int>> permute(vector<int>nums)
       {
           vector<vector<int>> res;
           solvePermute(res,nums,0);
           return res;
       }
       
       void solvePermute(vector<vector<int>>& res,vector<int> nums,int begin)
       {
           if(begin>=nums.size())
           {
               res.push_back(nums);
               return;
           }
           for(int i=begin;i<nums.size();++i)
           {
               swap(nums[i],nums[begin]);
               solvePermute(res,nums,begin+1);
               swap(nums[i],nums[begin]);
           }
       }
    };

    int main()
    {
       int n;
       while(cin>>n)
       {
           vector<int> ve(n);
           for(int i=0; i<n; ++i)
               cin>>ve[i];
           Solution solution;
           vector<vector<int>> ans=solution.permute(ve);
           for(auto p1:ans)
           {
               for(auto p2:p1)
               {
                   cout<<p2<<" ";
               }
               cout<<endl;
           }
       }
       return 0;
    }
  • 相关阅读:
    hdu 1455 N个短木棒 拼成长度相等的几根长木棒 (DFS)
    hdu 1181 以b开头m结尾的咒语 (DFS)
    hdu 1258 从n个数中找和为t的组合 (DFS)
    hdu 4707 仓鼠 记录深度 (BFS)
    LightOJ 1140 How Many Zeroes? (数位DP)
    HDU 3709 Balanced Number (数位DP)
    HDU 3652 B-number (数位DP)
    HDU 5900 QSC and Master (区间DP)
    HDU 5901 Count primes (模板题)
    CodeForces 712C Memory and De-Evolution (贪心+暴力)
  • 原文地址:https://www.cnblogs.com/crazyacking/p/5255205.html
Copyright © 2011-2022 走看看