[英]next_permutation of vector of strings is skipping one permutation
我正在尝试打印字符串向量的所有排列。 此代码按预期工作:
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main() {
vector<string> v;
v.push_back("+1");
v.push_back("x4");
do {
cout << v[0] << " " << v[1] << endl;
} while (next_permutation(v.begin(), v.end()));
}
输出:
+1 x4
x4 +1
但是当我将“x4”更改为“*4”时,next_pemutation 循环只迭代一次。
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main() {
vector<string> v;
v.push_back("+1");
v.push_back("*4");
do {
cout << v[0] << " " << v[1] << endl;
} while (next_permutation(v.begin(), v.end()));
}
输出:
+1 *4
其他字符如 # 似乎具有相同的效果。 为什么会发生?
您的算法需要从排序vector
开始打印所有排列:
"+1" < "x4"
( '+' < 'x'
):所以你真的从“第一个”排列开始。
"+1" > "*4"
( '+' > '*'
):所以你不会从第一个排列开始。
请参阅 man ascii 以获取char
的顺序(ascii 是最受欢迎的一种,但平台可以使用其他作为 EBCDIC)。
要解决您的问题,您可以在最后一次push_back
之后执行:
std::sort(v.begin(), v.end());
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.