STL中next_permutation和prev_permutation:a,b,c三个字符所组成的序列有六个可能的排列组合:abc,acb,bac,bca,cab,cba。这些排列组合根据less-than操作符做字典顺序(lexicographical)的排序。也就是说,abc名列第一,因为每一个元素都小于其后的元素。acb是次一个排列组合,因为它是固定了a(序列内最小元素)之后所做的新组合。
同样,那些固定b(序列中次小元素)而做的排列组合,在次序上将先于那些固定c而做的排列组合。以bac和bca为例,bac在bca之前,因为次序ac小于序列ca。面对bca,我们可以说其前一个排列组合是bac,而其后一个排列组合是cab。序列abc没有“前一个”排列组合,cba没有“后一个”排列组合。next_permutation()取[first,last)的下一个排列组合,如果没有下一个便返回false,否则返回true。
力扣面试题 08.07. 无重复字符串的排列组合:
无重复字符串的排列组合。编写一种方法,计算某字符串的所有排列组合,字符串每个字符均不相同。链接:https://leetcode-cn.com/problems/permutation-i-lcci/
class Solution {
public:
vector<string> permutation(string S) {
sort(S.begin(), S.end());
vector<string> res;
res.push_back(S);
while(next_permutation(S.begin(), S.end())) {
res.push_back(S);
}
return res;
}
};