如何产生1000个从1到1000之间的不重复的随机数,用C语言实现!

如题所述

#include<stdio.h>
#include<stdlib.h> /*rand()函数的头文件*/
#define N 1000

/* rand()产生一个伪随机数*/
void main()
{
int i=0,j,a[N]={-1},flag;

while(i<N)
{
flag = 1 + N * rand()/(RAND_MAX+1); /*rand()/RAND_MAX 该式表示所得到的是集合[0,1]中的随机数
若是使用rand()/(RAND_MAX+1) 则可得到集合[0,1)中的随机数
1000 * rand()/(RAND_MAX+1)可产生[0,1000),取整则是[0,999]中的随机数*/
j=0;
for(;j<i;j++)
{
if(a[j] == flag) break; //查找数组中是否已经有了随机产生的值,有则跳出循环,重新产生,无则存入数组
}
if(j>=i) {
a[j] = flag;
i++;
}
}
for(int k=0;k<N;k++)
printf("%5d",a[k]);
}

上面这个程序完全可以产生从1-1000的随机数,不信的话可以使用排序法查看所得结果。
温馨提示:内容为网友见解,仅供参考
第1个回答  2010-12-02
//以下程序是产生0到9之间10个不重复的随机数。你参考一下,这个是我搜索的,你有什么问题搜索一下吧,或者到CSDN论坛上提问。

#include <stdlib.h> //标准工具库,要用到其中的rand()
#include <stdio.h>
#include<conio.h>
#include <time.h> //时间库,要用到里面的时间来做随机数的种子

int main(void)
{
int i;
int r;
int sz[10]={0,1,2,3,4,5,6,7,8,9};
srand(time(NULL));

printf("Ten random numbers from 0 to 9\n\n");
for(i=0; i<10; i++)
{
r=rand()%(10-i);

printf("%d\n",sz[r]);

for(int j=r;j<10;j++)
sz[j]=sz[j+1];

}
getch();
return 0;
}本回答被网友采纳
相似回答