美文网首页
C++ STL shuffle 使用说明

C++ STL shuffle 使用说明

作者: book_02 | 来源:发表于2019-10-14 18:50 被阅读0次

说明

使用一个随机数产生器来打乱[first, last)之间元素的顺序。

有3个参数,前2个参数指定容器的范围,第3个参数指定随机数产生器。

函数签名如下:

template <class RandomAccessIterator, class URNG>
  void shuffle (RandomAccessIterator first, RandomAccessIterator last, URNG&& g);

shuffle的大致原理

The function swaps the value of each element with some other randomly picked element

通过交换元素来实现的,顺次交换当前元素和一个随机选择的元素。

头文件

#include <algorithm>

例子:随机打乱一个数组

#include <iostream>
#include <random>
#include <algorithm>

int main()
{
    std::vector<int> v = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
    std::cout << "before shuffle:\t";
    for (int n : v) {
        std::cout << n << "   ";
    }
    std::cout << std::endl;

    std::random_device rd;
    std::mt19937 rng(rd());

    std::shuffle(v.begin(), v.end(), rng);

    std::cout << "after shuffle: \t";
    for (int n : v) {
        std::cout << n << "   ";
    }
    std::cout << std::endl;

    return 0;
}

一种可能结果如下:

before shuffle: 1   2   3   4   5   6   7   8   9
after shuffle:  6   5   7   4   1   8   3   9   2

下面的代码是用来生成一个随机数产生器的

std::random_device rd;
std::mt19937 rng(rd());

随机数发生器使用有很多种,也可以使用如下的形式

unsigned seed = std::chrono::system_clock::now().time_since_epoch().count();
std::shuffle(v.begin(), v.end(), std::default_random_engine(seed));

random_shuffle 和 shuffle的区别

推荐使用std::shuffle

std::shuffle是从C++11之后才开始出现,必须与随机数生成器一起使用。

std::random_shuffle在C++11之前就已经存在,可以不指定随机数生成器而使用默认的随机数生成器。

需要注意的是,std::random_shuffleC++14 中弃用, C++17 中移除。所以推荐使用std::shuffle

std::random_shuffle被废除的原因是std::random_shuffle的随机数产生器使用了std::rand()
std::rand()使用了一个全局静态变量保存其状态,这样使得std::rand()无法同时产生两个独立互不干扰的随机数流。
所以std::random_shuffle由于使用了std::rand(),产生的随机数质量不如std::shuffle使用的均匀分布的随机数产生器URNG(Uniform Random Number Generator)产生的随机数

参考

https://zh.cppreference.com/w/cpp/algorithm/random_shuffle
http://www.cplusplus.com/reference/algorithm/shuffle/
https://meetingcpp.com/blog/items/stdrandom_shuffle-is-deprecated.html
https://www.geeksforgeeks.org/shuffle-vs-random_shuffle-c/

相关文章

  • C++ STL shuffle 使用说明

    说明 使用一个随机数产生器来打乱[first, last)之间元素的顺序。 有3个参数,前2个参数指定容器的范围,...

  • 读书笔记17.06.03

    C++ STL:Listlist是C++标准模版库(STL,Standard Template Library)中...

  • [C++] STL 容器

    参考:[C++] STL 容器 (一) - 基本介紹[C++] STL 容器 (二) - Iterator 部分示例:

  • C++ STL 学习笔记

    C++ STL 学习笔记

  • STL之参考文献

    C++标准库是离不开模板的,STL占了C++标准库80%以上。 学习STL(c++ 98)的主要参考: gcc 3...

  • C++ STL multiplies 使用说明

    说明 std::multiplies是乘法的二元函数对象。 常被用于std::transform或者std::ac...

  • C++ STL accumulate 使用说明

    说明 std::accumulate 用于对容器[first,last)内的元素和初始值init进行累积运算。 前...

  • 任务列表

    C++ 《C++ primer》、《STL源码解析》、《effective C++》、《深度搜索c++对象模型》 ...

  • STL初认识

    一 C++ 与STL 历史 STL全称standard template library,由Alexander S...

  • C++入门系列博客五 C++ STL

    C++ 标准模板库(STL) 作者:AceTan,转载请标明出处! 0x00 何为STL## STL(Standa...

网友评论

      本文标题:C++ STL shuffle 使用说明

      本文链接:https://www.haomeiwen.com/subject/nfcdmctx.html