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

leetcode 之Permutation(七)

时间:2016-05-15 16:36:00      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:

首先是next permutation的算法的描述和分析如下:

技术分享

 

技术分享

              这题一是要知道思路,编程中注意STL的用法       

技术分享
 void nextPermutaion(vector<int> &num)
      {
          next_permutation(num.begin(), num.end());
      }
private:
    template<typename BidiIt>
    bool next_permutation(BidiIt first, BidiIt last)
    {
        //反向,注意!
        auto rfirst = reverse_iterator<BidiIt>(last);
        auto rlast = reverse_iterator<BidIt>(first);
        auto pivot = next(rfirst);
        while (pivot != rlast && *pivot > *prev(pivot))
            pivot++;

        if (pivot == rlast)
        {
            reverse(rfist, rlast);
            return false;
        }
        //注意用法
        auto change = find_if(rfirst, pivot, bind1st(less<int>(), *pivot));
        swap(*pivot, *change);
        reverse(rfirst, pivot);

        return true;
    }
View Code

 接着是Permutation Sequence

 技术分享

 人用康托编码来解这个问题,不过个人觉得不太好理解,其实完全可以用上题的思路

 

技术分享
string getPermutaion(int n, int k)
      {
          string s(n, 0);
          for (int i = 0; i < n; i++)
              s[i] += i + 1;

          for (int i = 0; i < k; i++)
              next_permutation(s.begin(), s.end());

          return s;
      }
View Code

 

leetcode 之Permutation(七)

标签:

原文地址:http://www.cnblogs.com/573177885qq/p/5495306.html

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