zoukankan      html  css  js  c++  java
  • 泛型算法(十七)之随机洗牌算法

    1、random_shuffle(RandomAccessIterator first, RandomAccessIterator last):n个元素有n!个排列。该函数给出随机选择的一个排列。

        std::vector<int> c = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
    
        //把序列c中的元素随机打乱顺序
        std::random_shuffle(c.begin(), c.end());
        //输出
        for (auto var : c)
        {
            std::cout << var << ",";
        }
        //打印结果:8,1,9,2,0,5,7,3,4,6,

    2、random_shuffle(RandomAccessIterator first, RandomAccessIterator last, RandomNumberGenerator& gen):使用给定的随机数发生器来生产随机选择的一个排列。

        std::vector<int> c = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
    
        //使用给定的随机数发生器把序列c中的元素随机打乱顺序
        std::random_shuffle(c.begin(), c.end(), [](int i){
            return std::rand() % i;
        });
        //输出
        for (auto var : c)
        {
            std::cout << var << ",";
        }
        //打印结果:8,1,9,2,0,5,7,3,4,6,

    3、shuffle(RandomAccessIterator first, RandomAccessIterator last, URNG&& g):C11版,其中参数g为随机数发生器(uniform random number generator),如在<random>中定义的标准随机数发生器。

  • 相关阅读:
    python修改镜像源
    nginx 记录
    linux 常用命令
    修改ssh连上默认目录
    sqlplus 导出一张表数据
    推送kafka消息失败
    Mybatis generator配置
    Oracle导库
    docker -- 安装mysql8.0.16
    安装自动集成工具jenkins
  • 原文地址:https://www.cnblogs.com/dongerlei/p/5145074.html
Copyright © 2011-2022 走看看