本文主要是介绍投硬币概率模拟程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
#include <stdio.h>
#include <stdlib.h>
//头像面朝上的概率
int heads()
{
return rand() < RAND_MAX/2;
}
int main(int argc, char *argv[])
{
int i, j, cnt;
//N为每次实验投币的次数,M为实验的次数
int N = atoi(argv[1]), M = atoi(argv[2]);
int *f = malloc((N+1) * sizeof(int));
for (i = 0; i <= N; i++) f[i] = 0;
for (j = 0; j < M; j++, f[cnt]++)
for (cnt = 0, i = 0; i <= N; i++)
if (heads()) cnt++;
for (i = 0; i <= N; i++)
{
printf("%2d ", i);
for (j = 0; j < f[i]; j += 10) printf("*");
printf("\n");
}
}
执行结果如下:
[img]http://dl.iteye.com/upload/attachment/508358/a98524ee-82fc-382d-a031-1a349cd43677.bmp[/img]
不过有点疑惑的是这个结果并不是完全与概率学的正态分布吻合,有点小的偏差,而经过几次执行的结果好像都没有变化,这点有点疑问,可能和伪随机数的产生机制有关吧...
这篇关于投硬币概率模拟程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!