生产随机的矩阵的关键在于使用随机函数rand()。
rand()
表头文件: #include
定义函数 :int rand(void)
函数说明 :
因为rand的内部实现是用线性同余法做的,他不是真的随机数,只不过是因为其周期特别长,所以有一定的范围里可看成是随机的,rand()会返回一随机数值,范围在0至RAND_MAX 间。在调用此函数产生随机数前,必须先利用srand()设好随机数种子,如果未设随机数种子,rand()在调用时会自动设随机数种子为1。rand ()产生的是假随机数字,每次执行时是相同的。若要不同,以不同的值来初始化它.初始化的函数就是srand()。
返回值:
返回0至RAND_MAX之间的随机整数值,RAND_MAX的范围最少是在32767之间(int),即双字节(16位数)。若用unsigned int 双字节是65535,四字节是的整数范围。
0~RAND_MAX每个数字被选中的机率是相同的.
基于随机函数,使用双重循环语句便可以生成一个随机矩阵,下面是一个10×10随机矩阵的代码,数值范围在0~1000:#include
#include
#define M 10
#define N 10
int main(void)
{
int i = 0, j = 0;
int Arr[M][N] = {
{0}};
srand(time(NULL));
for (i = 0; i
{
for (j = 0; j
{
Arr[i][j] = rand() % 1000;
}
}
printf(“Array[%d][%d] is: \n”, M, N);
for (i = 0; i
{
for (j = 0; j
{
printf(“%d\t”, Arr[i][j]);
}
printf(“\n”);
}
return 0;
}
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/224983.html原文链接:https://javaforall.net
