C 语言

关注公众号 jb51net

关闭
首页 > 软件编程 > C 语言 > C++ std::shuffle

C++中std::shuffle的使用小结

作者:点云SLAM

std::shuffle是C++标准库中的一个函数,用于对容器中的元素进行随机排列,本文主要介绍了C++中std::shuffle的使用小结,具有一定的参考价值,感兴趣的可以了解一下

std::shuffle 的使用

std::shuffle 是 C++ 标准库中的一个函数,用于对容器中的元素进行随机排列(洗牌)。它的实现基于现代随机数生成器,因此比 std::random_shuffle 更安全和灵活(std::random_shuffle 在 C++14 被弃用,C++17 后被移除)。

1. 语法

#include <algorithm>
#include <random>

std::shuffle(RandomIt first, RandomIt last, URBG&& g);

2. 使用示例

#include <iostream>
#include <vector>
#include <algorithm>
#include <random>  // 需要包含 <random> 头文件

int main() {
    std::vector<int> vec = {1, 2, 3, 4, 5, 6, 7, 8, 9};

    // 创建随机数生成器
    std::random_device rd;  // 随机设备(硬件熵源)
    std::mt19937 g(rd());   // 梅森旋转算法(常用的随机数引擎)

    // 打乱顺序
    std::shuffle(vec.begin(), vec.end(), g);

    // 输出打乱后的结果
    std::cout << "Shuffled vector: ";
    for (int num : vec) {
        std::cout << num << " ";
    }
    std::cout << std::endl;

    return 0;
}

3. 代码解析

4. 示例输出

Shuffled vector: 3 7 5 9 1 4 2 8 6

(输出的顺序是随机的,每次运行结果可能不同。)

5. 重要说明

为什么不用 std::random_shuffle

std::mt19937 vs std::default_random_engine

如何使用固定种子进行可复现的随机洗牌?

std::mt19937 g(42);  // 42 作为固定的随机种子
std::shuffle(vec.begin(), vec.end(), g);

这样每次运行代码都会得到相同的打乱结果。

6. 适用场景

7. 结论

std::shuffle 是现代 C++ 中推荐的随机洗牌方法,结合 std::mt19937 可以提供高质量的随机性,适用于各种随机排列的场景。

🚀 推荐使用 std::shuffle 代替 std::random_shuffle,并搭配 std::mt19937 以获得更好的随机性和可控性!

到此这篇关于C++中std::shuffle的使用小结的文章就介绍到这了,更多相关C++ std::shuffle内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文