首页 > 后端开发 > C++ > 如何使用'std::next_permutation”和'std::prev_permutation”在 C 中高效生成组合?

如何使用'std::next_permutation”和'std::prev_permutation”在 C 中高效生成组合?

Susan Sarandon
发布: 2024-12-03 13:05:12
原创
476 人浏览过

How Can I Efficiently Generate Combinations in C   Using `std::next_permutation` and `std::prev_permutation`?

在 C 语言中生成组合

问题介绍

生成组合是各种语言中的常见操作编程场景。它包括创建包含来自较大集合的指定数量元素的集合。本文探讨了如何解决在 C 中生成组合的挑战。

使用 std::next_permutation 的解决方案

一种有效的方法是利用 std::next_permutation 函数来自 C 标准库。这是一个实现:

#include <iostream>
#include <algorithm>
#include <vector>

int main() {
    int n, r;
    std::cin >> n >> r;

    std::vector<bool> v(n);
    std::fill(v.end() - r, v.end(), true);

    do {
        for (int i = 0; i < n; ++i) {
            if (v[i]) {
                std::cout << (i + 1) << " ";
            }
        }
        std::cout << "\n";
    } while (std::next_permutation(v.begin(), v.end()));
    return 0;
}
登录后复制

此解决方案首先创建一个选择数组 (v) 并将 r 选择器放置在最后 r 个位置。 std::next_permutation 函数生成这些选择器的所有排列。对于每个排列,它都会打印与所选位置相对应的集合成员。

与 std::prev_permutation 替代

对于组合应以不同方式输出的情况顺序,请考虑使用 std::prev_permutation 代替:

#include <iostream>
#include <algorithm>
#include <vector>

int main() {
   int n, r;
   std::cin >> n >> r;

   std::vector<bool> v(n);
   std::fill(v.begin(), v.begin() + r, true);

   do {
       for (int i = 0; i < n; ++i) {
           if (v[i]) {
               std::cout << (i + 1) << " ";
           }
       }
       std::cout << "\n";
   } while (std::prev_permutation(v.begin(), v.end()));
   return 0;
}
登录后复制

此变体会交替顺序的组合,使输出更容易解释。

以上是如何使用'std::next_permutation”和'std::prev_permutation”在 C 中高效生成组合?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板