zoukankan      html  css  js  c++  java
  • [leetcode] permutations 排列

    写了两个,一个是直接的递归实现:

    class Solution {
    public:
    
        void swap(vector<int> &num,int left,int right)
        {
            num[left] = num[left]^num[right];
            num[right] = num[left]^num[right];
            num[left] = num[left]^num[right];
        }
    
        void permuteHelp(vector<int> &num,int fix,vector< vector<int> > &result)
        {
            if(fix==num.size()-1)
            {
                result.push_back(num);
                return;
            }
            permuteHelp(num,fix+1,result);
            for(int i=fix+1;i<num.size();i++)
            {
                swap(num,i,fix);
                permuteHelp(num,fix+1,result);
                swap(num,i,fix);
            }
        }
    
        vector<vector<int> > permute(vector<int> &num) {
            vector< vector<int> > result;
            if (num.size()<1)
                return result;
            if(num.size()<2)
                result.push_back(num);
            else
                permuteHelp(num,0,result);
            return result;
        }
    };

    另外一个是通过类似STL 的 next_permutation 函数方法实现:

    下面链接是 STL 的 next_permutation 函数 描述:

    http://www.cnblogs.com/Azhu/articles/3897586.html

    按字典左起从小到达顺序给出当前序列的下一个排序,适用于序列中有重复元素的情况,函数的过程是:

    1.右起寻找相邻的两数,满足next<next1

    2.右起寻找第一个大于next的数,记为mid

    3.交换 mext 与mid

    4.逆序next1 (包括next1)到右末尾

    class Solution{
    public:
    
        int factorial(int n)
        {
            return n<2?1:factorial(n-1)*n;
        }
    
        void next_per(vector<int> & num)
        {
            vector<int>::iterator first,last,next,next1,mid;
            first = num.begin();
            last = num.end();
            next = last;
            if(first==--next||first==last)
                return ;
            while(1)
            {
                next1=next--;
                if(*next<*next1)
                {
                    mid = last;
                    while(!(*next<*--mid));
                    iter_swap(next,mid);
                    reverse(next1,last);
                    return ;
                }
                if(next==first)
                {
                    reverse(first,last);
                    return ;
                }
            }
        }
    
        vector< vector<int> > permute(vector<int> &num)
        {
            vector< vector<int> > result;
            if(num.size()<1)
                return result;
            sort(num.begin(),num.end());
            result.push_back(num);
            for(int i=1;i<factorial(num.size());i++)
            {
                next_per(num);
                result.push_back(num);
            }
            return result;
        }
    };

    main函数:

    #include <vector>
    #include <iostream>
    #include <algorithm>
    using namespace std;
    int main()
    {
        vector<int> num;
        int a = 2;
        for(int i=0;i<a;i++)
            num.push_back(i);
        Solution solution;
        vector< vector<int> > result;
        result = solution.permute(num);
        for(int id = 0;id<result.size();id++)
        {
            for(int i=0;i<a;i++)
                cout<<result[id][i]<<' ';
            cout<<endl;
        }
        cout<<result.size()<<endl;
        return 0;
    }
  • 相关阅读:
    windows设置通过NFS连接到Linux共享数据
    MYSQL安装相关知识
    Linux下Eclipse里用gdb调试JNI里C/C++
    linux上安装Eclipse
    vs2010常用快捷键
    .NET Framework 2.0/3.0/3.5 以 v90 平台工具集为目标。请确保在计算机上安装了 Visual Studio 2008
    C++ ->error LNK1123
    Python 函数
    Python安装工具
    Web接口测试理论知识分享
  • 原文地址:https://www.cnblogs.com/Azhu/p/3897633.html
Copyright © 2011-2022 走看看