C++:无法掌握std::next_permination和std::prev_permutation的工作
C++: Trouble grasping std::next_permutation and std::prev_permutation work
EDIT:对不起,这只是我在下面代码中初始化时的错误。
const int kDigits = 7;
std::vector<int> number(kDigits);
for (int i = kDigits - 1; i >= 0; i--) {
number[i] = i + 1;
}
向量CCD_ 1被初始化为CCD_
我的目标是按递减顺序生成排列:7654321
7654312
7654231
7654213
7654132
此代码有效:
do {
...
}
while (std::prev_permutation(number.rbegin(), number.rend()));
然而,我不明白为什么。既然7654321
是最大的字典排列,那么while (std::prev_permutation(number.begin(), number.end()));
(没有反向迭代器)不应该正确地生成它吗?因为它会按顺序生成前一个排列吗?然而,这在第一次尝试时返回false,即使它应该生成"较低排列"
此外,在上面显示的代码中,由于它使用了反向迭代器,我的大脑将其解释为找到1234567
的前一个排列(7654321
向后),在我看来,它应该没有。
非常感谢您提前提供的帮助!我期待着弄清楚我误解了什么/错过了什么。
向量number
初始化为1,2,3,4,5,6,7
,而不是number
0。这就是您的代码工作的原因。
如果要将其初始化为7,6,5,4,3,2,1
,则需要修复初始化例程。
根据定义,第一个排列没有前向排列。否则就不会是第一了。这就是为什么您需要rbegin
来获得反向迭代器的"第一个"排列(这是最后一个排列)。
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- 使用一个考虑到std::map中键值的滚动或换行的键
- 如何从 std::atomic 中提取指针 T<T>?
- 为什么 std::unique 不调用 std::sort?
- 使用std::函数映射对象方法
- 为什么' std::prev '不会用' std::unordered_set '的迭代器引发错误?