我编写了一个代码来打印 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 个随机数。
您可以使用两个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;
}
如果您正在寻找矩阵中的所有唯一数字:
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;
}
除了 jh314 的回答,这里有一个方便的函数来获取一个区间内的随机数。
int random_int(int min, int max) {
return min + rand() % (max - min + 1)
}