下一个排列
题目描述
实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列。
如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列)。
必须原地修改,只允许使用额外常数空间。
样例
- 1,2,3 → 1,3,2
3,2,1 → 1,2,3
1,1,5 → 1,5,1
Code
时间复杂度O(n),空间复杂度O(1);
void nextPermutation(vector<int>& nums) {
next_permutation(nums.begin(), nums.end());
}
template<typename BidiIt>
bool next_permutation(BidiIt first, BidiIt last) {
const auto rfirst = reverse_iterator<BidiIt>(last);
const auto rlast = reverse_iterator<BidiIt>(first);
auto pivot=next(rfirst);
while(pivot !=rlast && *pivot >= *prev(pivot)) {
++pivot;
}
if(pivot ==rlast) {
reverse(rfirst, rlast);
return false;
}
auto change=find_if(rfirst, pivot, bind1st(less<int>(), *pivot));
swap(*change, *pivot);
reverse(rfirst, pivot);
return true;
}