std:: discrete_distribution
|
Défini dans l'en-tête
<random>
|
||
|
template
<
class
IntType
=
int
>
class discrete_distribution ; |
(depuis C++11) | |
std::discrete_distribution
produit des entiers aléatoires sur l'intervalle
[
0
,
n
)
, où la probabilité de chaque entier individuel
i
est définie comme
w
i
/S
, c'est-à-dire le
poids
du
i
-ième entier divisé par la somme de tous les
n
poids.
std::discrete_distribution
satisfait toutes les exigences de
RandomNumberDistribution
.
Table des matières |
Paramètres du modèle
| IntType | - | Le type de résultat généré par le générateur. L'effet est indéfini si ce n'est pas l'un des short , int , long , long long , unsigned short , unsigned int , unsigned long , ou unsigned long long . |
Types membres
| Type de membre | Définition |
result_type
(C++11)
|
IntType |
param_type
(C++11)
|
le type du jeu de paramètres, voir RandomNumberDistribution . |
Fonctions membres
|
(C++11)
|
construit une nouvelle distribution
(fonction membre publique) |
|
(C++11)
|
réinitialise l'état interne de la distribution
(fonction membre publique) |
Génération |
|
|
(C++11)
|
génère le prochain nombre aléatoire dans la distribution
(fonction membre publique) |
Caractéristiques |
|
|
obtient la liste des probabilités
(fonction membre publique) |
|
|
(C++11)
|
obtient ou définit l'objet paramètre de distribution
(fonction membre publique) |
|
(C++11)
|
retourne la valeur potentiellement générée minimale
(fonction membre publique) |
|
(C++11)
|
retourne la valeur potentiellement générée maximale
(fonction membre publique) |
Fonctions non membres
|
(C++11)
(C++11)
(supprimé en C++20)
|
compare deux objets de distribution
(fonction) |
|
(C++11)
|
effectue des opérations d'entrée/sortie sur flux pour une distribution de nombres pseudo-aléatoires
(modèle de fonction) |
Exemple
#include <iomanip> #include <iostream> #include <map> #include <random> int main() { std::random_device rd; std::mt19937 gen(rd()); std::discrete_distribution<> d({40, 10, 10, 40}); std::map<int, int> map; for (int n = 0; n < 1e4; ++n) ++map[d(gen)]; for (const auto& [num, count] : map) std::cout << num << " generated " << std::setw(4) << count << " times\n"; }
Sortie possible :
0 generated 4037 times 1 generated 962 times 2 generated 1030 times 3 generated 3971 times