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

Next Permutation

时间:2016-03-11 18:34:58      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:

不懂为什么这么做

在当前序列中,从尾端向前寻找两个相邻元素,前一个记为*i,后一个记为*t,并且满足*i < *t。然后再从尾端

寻找另一个元素*j,如果满足*i < *j,即将第i个元素与第j个元素对调,并将第t个元素之后(包括t)的所有元

素颠倒排序,即求出下一个序列了。

  STL中有这个next_permutation函数

 

 1 class Solution {
 2 public:
 3     void nextPermutation(vector<int>& nums) {
 4         if(nums.size()<2) return;
 5         int i,k;
 6         for(i= nums.size()-2;i>=0;--i)
 7          if(nums[i]<nums[i+1])
 8          break;
 9          for(k=nums.size()-1;k>i;--k)
10          if(nums[i]<nums[k])
11          break;
12          if(i>=0) swap(nums[i],nums[k]);
13          reverse(nums.begin()+i+1,nums.end());
14     }
15 };

 

Next Permutation

标签:

原文地址:http://www.cnblogs.com/daocaorenblog/p/5266655.html

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