随机数模拟概率现象

  • Post author:
  • Post category:其他


三十人的班级,出现生日重复的概率有多大


非常有意思的是这个简单的代码给了我许多启发

/*
	假设一年为365天
	宏常量: 
		N:模拟次数 
		NUM:一个班级学生人数  
		AYEARDAY:一年有多少天 
*/

#include<stdio.h>
#include<time.h>   
#define N 100000   //模拟次数 
#define NUM 30    //一个班级学生人数 
#define AYEARDAY 365 //一年有多少天 

void getRandBirth(int student[],int length);  //随机生成一个班级所有学生的生日 
int isRepeate(int student[],int length); //判断班级中是否有生日重复的 
void main(){
	int student[NUM];
	int i;
	int count;  //计数:班级学生生日有重复的数目 
	srand(time(NULL));
	count=0;
	for(i=0;i<N;i++){
		getRandBirth(student,NUM);
		if(isRepeate(student,NUM)) count++;
	}
	printf("%d\n",count);
	printf("%d人的班级中学生出现生日重复的概率为%.2f\n",NUM,((float)count)/N);
	
	return ;
} 

void getRandBirth(int student[],int length){
	int i;
	
	for(i=0;i<length;i++){
		student[i]=rand()%AYEARDAY+1;
	}
	return;
} 
int isRepeate(int student[],int length){
	/*
		返回值:
			1:该班级的学生生日有重复
			0:该班级的学生生日没有重复 
	*/
	int i,j;
	for(i=0;i<length;i++){
		for(j=0;j<length;j++){
			if(i==j) continue;
			if(student[i]==student[j]){
				return 1;
			}
		}
	}
	return 0;
}


我也在思考一个问题,博客是写给别人看还是给自己看,我想给别人看,但一者人与人之间的语言的语言差异很大,二者语言本身也是苍白的,因而也很难将自己的一些美妙的想法说明白。



版权声明:本文为qq_41962663原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。