当前位置: 代码迷 >> 综合 >> 编写程序:掷2000次,每次掷两颗骰子,用二维数组记录每次的情况,其中数组的行为第一次的情况,列为第二次情况
  详细解决方案

编写程序:掷2000次,每次掷两颗骰子,用二维数组记录每次的情况,其中数组的行为第一次的情况,列为第二次情况

热度:34   发布时间:2024-01-17 02:07:10.0

题目

编写程序:掷2000次,每次掷两颗骰子,用二维数组记录每次的情况,其中数组的行为第一次的情况,列为第二次情况
例如:
第一次:1 3
第二次:6 6
二维数组:
0 0 1 0 0 0
0 0 0 0 0 0
0 0 0 0 0 0
0 0 0 0 0 0
0 0 0 0 0 0
0 0 0 0 0 1

说明:
因为计算机没有真正的随机数,但是可以得出伪随机数。其中srand()函数可以传入一个“种子”,若每次“种子”是一样的,那么rand()函数求出来的随机数也都是一样的。

但是,在现实生活中,每时每刻的时间都是不一样的,因此我们可以将当前的时间作为种子,这样就使得获取的随机数不一样。

因此在使用rand()产生随机数之前,我们需要加一条语句:
srand(time(NULL));
其中srand()和rand()的头文件为 <stdlib.h>
time()的头文件为 <time.h>

#include <iostream>
#include <time.h>
#include <stdlib.h>using namespace std;void printFun(int (*ptr)[6]){
    for(int i=0;i<6;i++){
    for(int j=0;j<6;j++){
    cout<<ptr[i][j]<<" ";}cout<<endl;}
}int main()
{
    int b[6][6]={
    0};srand(time(NULL));int m=1,n=6;//使得rand()产生的数范围在[1,6]之间的整数for(int i=0;i<2000;i++){
    int first = (rand() % (n-m+1))+ m;  //第一次面数int second = (rand() % (n-m+1))+ m; //第二次面数b[first-1][second-1]++;}printFun(b);return 0;
}
  相关解决方案