zoukankan      html  css  js  c++  java
  • 掷色子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;
    }
    

      

     update:2018.10.17

    int main()
    {
    	int count[6] = { 0 };
    	srand(time(0));
    	int res = 0;
    
    	for (int i = 1; i <= 6000; i++)
    	{
    		res = (rand() % 6) + 1;
    		count[res - 1]++;
    	}
    
    	for (int j = 1; j <= 6; j++)
    	{
    		printf("%d:%d
    ",j,count[j - 1]);
    	}
    
    }
    

    优化了一下代码。

  • 相关阅读:
    网络传输协议 UDP & TCP 详解
    OSI 七层协议
    (01day)python接口测试
    Python2和Python3的区别,以及为什么选Python3的原因
    JAVA反编译工具
    JAR反编译工具
    webdriver19-witchto方法
    webdriver实例14-Xpath定位的几种方法
    webdirver实例1--查找元素
    Qt插件开发
  • 原文地址:https://www.cnblogs.com/yfish/p/9800510.html
Copyright © 2011-2022 走看看