首页 > 其他 > 详细

掷色子6000次分别统计出点子出现的次数

时间:2018-10-16 21:12:14      阅读:107      评论:0      收藏:0      [点我收藏+]

由于刚学习了数组,那么就用数组了。

可能出现的点子是1~6共六种,而且次数是一个整数,所以我们定义一个包含6个元素的整型数组来存放结果

int count[6]={0}

看题目做6000次,这是重复做一件事情,我们可以用for循环

for(int i=1;i<=6000;i++)//i表示做一件事情的次数

上面的for循环意思是重复做一件事情6000次,做什么呢?掷色子,那么掷色子这件事情就要写在for循环的循环体中。

掷色子是一个随机过程,每次都会产生一个1~6的随机数,可以利用rand和srand来生成随机数,但是rand每次生成的随机数都相对比较大,怎么产生1~6之间的数呢? 可以用取余算法,任何整数只要对6取余,那么就会产生0~5之间的数,再加1就能产生1~6了,可以。把每次产生1~6之间的数分类讨论,如果是1,就让对应的count++ 。最后依次输出count[0]~count[5]就可以了。

 

int main(void)
{
	srand(time(0));



	int count[6] = {0};
	int res = 0;

	for (int i = 1; i <= 6000; i++)
	{
		res=(rand()%6)+1;


		switch (res)
		{
		case 1:count[0]++;
			break;
		case 2:count[1]++;
			break;
		case 3:count[2]++;
			break;
		case 4:count[3]++;
			break;
		case 5:count[4]++;
			break;
		case 6:count[5]++;
			break;
		}
	}


	for (int i = 1; i <= 6; i++)
	{
		printf("%d:%d\n",i,count[i-1]);
	}


	return 1;
}

  

 

掷色子6000次分别统计出点子出现的次数

原文:https://www.cnblogs.com/yfish/p/9800510.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!