首页 文章资讯内容详情

数据结构中的负二项式分布

2026-06-04 1 花语

负二项式分布是一个随机数分布,它将根据负二项式离散分布产生整数。这称为Pascal分布,因此负二项式分布可写为

$$P\lgroupi\arrowvertk,p\rgroup=\lgroup\frac{k+i-1}{i}\rgroupp^{k}\lgroup1-p\rgroup^{i}$$

示例

#include <iostream> #include <random> using namespace std; int main(){ const int nrolls = 10000; // number of rolls const int nstars = 100; // maximum number of stars to distribute default_random_engine generator; negative_binomial_distribution<int> distribution(3,0.5); int p[10]={}; for (int i=0; i<nrolls; ++i) { int number = distribution(generator); if (number<10) p[number]++; } cout << "negative_binomial_distribution (3,0.5):" << endl; for (int i=0; i<10; ++i) cout << i << ": " << string(p[i]*nstars/nrolls,*) << endl; }

输出结果

0: ************ 1: ******************* 2: ***************** 3: **************** 4: *********** 5: ******* 6: ***** 7: *** 8: ** 9: *