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

Posted yfish

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了掷色子6000次分别统计出点子出现的次数相关的知识,希望对你有一定的参考价值。

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

可能出现的点子是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
",i,count[i-1]);
	}


	return 1;
}

  

 

以上是关于掷色子6000次分别统计出点子出现的次数的主要内容,如果未能解决你的问题,请参考以下文章

python之pygal:掷两个不同的骰子并统计大小出现次数

python 由用户输入掷多少次骰子,然后统计每个面出现的次数

PHP制作的掷色子点数抽奖游戏实例

R掷硬币500次,出现真面朝上的概率

python之pygal:掷一个骰子统计次数并以直方图形式显示

概率dp 期望 逆推