Next_permutation返回奇怪的结果
next_permutation returning strange results
我试图找到给定字符列表的所有排列,在这种情况下'eta'
std::string s="eta";
do
{
std::cout<<s<<std::endl;
}while(std::next_permutation(s.begin(),s.end()));
,我会得到以下输出:
eta
tae
tea
但是如果我改变一件事
std::string s="eta";
std::string s="aet";
输出现在变成
aet
ate
eat
eta
tae
tea
是我期望的正确排列数;所以当"打乱"字符串按字母顺序排列时,显然发生了一些不同的事情?
或者是什么导致了这种歧义?
next_permutation
将序列更改为所有排列的排序顺序中的下一个排列。因此,如果您从不是字典顺序中的第一个排列开始,那么在next_permutation返回false之前,您将只获得所有排列的一部分。
正如同构函数指出的那样,下一个排列在上一个前进的排列上停止。因此,如果您想要所有的字符,只需sort
字符列表。
next_permutation将[first, last)范围内的元素重新排列成字典顺序上的下一个更大的元素排列,
所以你的输出没有问题:)
相关文章:
- 如何返回一个类的两个对象相加的结果
- 如果我std::dynamic_pointer_cast并且底层dynamic_cast的结果为null,那么返回的sh
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- C++Brute Force攻击函数不会返回结果
- 如何从递归函数中完全返回,该函数给出了每个函数结果的累积相加?
- 如何读取 C++ SAFEARRAY**,该 SAFEARRAY** 是 COM 互操作的结果,其中 C# 返回值为
- 为什么我的程序在 O0 和 O2 的优化级别返回不同的结果
- c++ lambda:柯里和函数:使用按值捕获与按引用捕获返回不同的结果
- C++ 获取函数在常量引用中按值返回的结果
- 如何在一个表达式中生成并返回结果?
- 从返回 std::optional of std::vector 的函数中获取结果到调用方
- 三元运算符在返回语句中给出意外的结果
- 为什么函数 tellg() 没有返回好的结果?
- 为什么我可以改变常量对象中的成员变量,这是返回常量对象函数的结果?
- 有没有办法将 for 循环结果返回到像三元运算符这样的函数中?
- 使用std::tie进行类似golang的错误处理,同时返回结果,是否有缺点?(C++11)
- 检查文本文件中的 0 或 1,并根据结果返回
- 如何使用boost::any_range连接多个boost范围并作为函数w/o的结果返回
- 如何从线程的结果返回Qt对象(Qtfutur)
- C++:当在函数内部创建新对象并将其作为结果返回时,我必须使用新运算符来创建对象