c++多种情况不同概率下,在范围内使用随机数

多种情况不同概率下,在范围内使用随机数。比如有5种情况,每种情况的概率不相同,有的概率为25,有的为15.

使用random库的函数来生成随机数。

cpp 复制代码
std::random_device rd;  //产生随机数种子
std::mt19937 gen(rd()); //生成伪随机数,使用rd作为种子
std::uniform_real_distribution<> dist(0, total_weight);  //生成指定范围均匀分布的实数
int random_number = dist(gen);  //调用均匀实数分布生成一个随机数

在五种概率情况下,通过生成随机数从五类中抽取一个随机结果。完整代码如下:

cpp 复制代码
#include <iostream>
#include <random>
#include <vector>


enum EMoonCakePieceType {
    E_PIECE_FLY = 0,    // 碎片1
    E_PIECE_LU = 1,    // 碎片2
    E_PIECE_CROSS = 2,    // 碎片3
    E_PIECE_MIDDLE = 3,    // 碎片4
    E_PIECE_AUTUMN = 4,    // 碎片5
};

int main() {
    std::random_device rd;
    std::mt19937 gen(rd());  // 设置种子

    // 每个字的概率
    std::vector<std::pair<int, int>> words = {{E_PIECE_FLY,    15},
                                              {E_PIECE_LU,     15},
                                              {E_PIECE_CROSS,  25},
                                              {E_PIECE_MIDDLE, 15},
                                              {E_PIECE_AUTUMN, 30}};
    // 计算总权重
    int total_weight = 0;
    for (std::vector<std::pair<int, int>>::const_iterator it = words.begin(); it != words.end(); ++it) {
        total_weight += it->second;
    }
    std::vector<int> chinese;
    std::uniform_real_distribution<> dist(0, total_weight);
    int random_number = dist(gen);

    int result_number = 4;
    int cumulative_weight = 0;
    for (std::vector<std::pair<int, int>>::iterator itb = words.begin(); itb != words.end(); ++itb) {
        cumulative_weight += itb->second;
        if (random_number <= cumulative_weight) {
            result_number = itb->first;
            break;
        }
    }
    std::cout << result_number << std::endl;
    chinese.push_back(result_number);
    std::cout << "生成了:";
    for (auto word: chinese) {
        std::cout << word << " ";
    }  // 测试结果
    std::cout << std::endl;

    return 0;
}

开启个while循环测试多次运行,代码运行结果如下:

cpp 复制代码
#include <iostream>
#include <random>
#include <vector>
#include <thread>


enum EMoonCakePieceType {
    E_PIECE_FLY = 0,    // 碎片1
    E_PIECE_LU = 1,    // 碎片2
    E_PIECE_CROSS = 2,    // 碎片3
    E_PIECE_MIDDLE = 3,    // 碎片4
    E_PIECE_AUTUMN = 4,    // 碎片5
};

int main() {
    std::random_device rd;
    std::mt19937 gen(rd());  // 设置种子

    // 每个字的概率
    std::vector<std::pair<int, int>> words = {{E_PIECE_FLY,    15},
                                              {E_PIECE_LU,     15},
                                              {E_PIECE_CROSS,  25},
                                              {E_PIECE_MIDDLE, 15},
                                              {E_PIECE_AUTUMN, 30}};
    // 计算总权重
    int total_weight = 0;
    for (std::vector<std::pair<int, int>>::const_iterator it = words.begin(); it != words.end(); ++it) {
        total_weight += it->second;
    }
    std::vector<int> chinese;
    while (true) {
        std::uniform_real_distribution<> dist(0, total_weight);
        int random_number = dist(gen);

        int result_number = 4;
        int cumulative_weight = 0;
        for (std::vector<std::pair<int, int>>::iterator itb = words.begin(); itb != words.end(); ++itb) {
            cumulative_weight += itb->second;
            if (random_number <= cumulative_weight) {
                result_number = itb->first;
                break;
            }
        }
        std::cout << result_number << std::endl;
        chinese.push_back(result_number);
        std::cout << "生成了:";
        for (auto word: chinese) {
            std::cout << word << " ";
        }  // 测试结果
        std::cout << std::endl;
        std::this_thread::sleep_for(std::chrono::seconds(3));
    }
    return 0;
}

代码运行结果示例如下:

相关推荐
房开民3 分钟前
可变参数模板
java·开发语言·算法
t***54423 分钟前
如何在现代C++中更有效地应用这些模式
java·开发语言·c++
不知名的忻28 分钟前
Morris遍历(力扣第99题)
java·算法·leetcode·morris遍历
状元岐41 分钟前
C#反射从入门到精通
java·javascript·算法
itman3011 小时前
C语言、C++与C#深度研究:从底层到现代开发演进全解析
c语言·c++·c·内存管理·编译模型
_深海凉_1 小时前
LeetCode热题100-除了自身以外数组的乘积
数据结构·算法·leetcode
Victoria.a2 小时前
python基础语法
开发语言·python
Kk.08022 小时前
项目《基于Linux下的mybash命令解释器》(一)
前端·javascript·算法
SteveSenna2 小时前
Trossen Arm MuJoCo自定义1:改变目标物体
人工智能·学习·算法·机器人
xiaoyaohou112 小时前
023、数据增强改进(二):自适应数据增强与AutoAugment策略
开发语言·python