3

我编写了一个代码来打印 5x6 数字矩阵,但我试图弄清楚如何使矩阵内的数字随机(如果可能,在区间内)。它与在行中获取随机数有多相似?

int row[50]
 srand(time(NULL));
 for(i=0;i<50;i++){
  row[i]=rand()%31+10;
  printf("%d ", row[i]);
 }

我今天早些时候使用此代码在 10-40 间隔内处理 50 个随机数。

4

3 回答 3

3

您可以使用两个for循环:

int array[5][6];
srand(time(NULL));
int x, y;
for(x = 0; x < 5; x++) {
    for(y = 0; y < 6; y++) 
        array[x][y] = rand() % 31 + 10;
}
于 2013-07-30T12:51:19.507 回答
1

如果您正在寻找矩阵中的所有唯一数字:

int used[30];
int count=0;

int check_used(int x)
{
int i;
for(i =0; i<count;i++)
    if(used[i] == x)
     return 1;

return 0;
}

int main()
{
    int r,i,j;
    int mat[5][6];

    srand (time(NULL));

    for (i=0;i<5;i++)
        for(j=0;j<6;j++)
        while(1)
        {
            r=rand()  % 31 + 10;
            if(!check_used(r))
            { mat[i][j]  = used[count++] =r;
              break;
            }
        }     
    return 0;
}
于 2013-07-30T13:00:22.277 回答
1

除了 jh314 的回答,这里有一个方便的函数来获取一个区间内的随机数。

int random_int(int min, int max) {
    return min + rand() % (max - min + 1)
}
于 2013-07-30T12:54:55.100 回答