| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3796 人关注过本帖
标题:[求助]:如何产生5000个0-10000的互不相同的随机数
只看楼主 加入收藏
lovelygirl
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-9-16
收藏
 问题点数:0 回复次数:33 
[求助]:如何产生5000个0-10000的互不相同的随机数

最近编程,要用到随机数。想请教各位高手如何产生5000个或者任意个0-10000的互不相同的随机数。
Head=(infected*)malloc(sizeof(infect));
Head->nex=NULL;
for(i=0;i<5000;i++)
{j=rand()%N;
s1=(infected*)malloc(sizeof(infect));
s1->adj=j;
s1->nex=Head->nex;
Head->nex=s1;
}
上面是我写的,但是这样得到的5000个随机数其中有相等的。我需要得到两两互不相等的随机数,不知道如何做,请各位指教,非常感谢!

搜索更多相关主题的帖子: 随机数 
2006-10-27 22:04
云中雾
Rank: 1
等 级:新手上路
威 望:1
帖 子:168
专家分:3
注 册:2005-12-30
收藏
得分:0 
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void main()
{
int i,j,k;
for(j=0;j<500;j++)
{
for(k=0;k<10;k++)
{
srand( i );
i=rand();
printf("%d\t",i);
}
printf("\n");
}
}

这上产生5000个没有重复随机数的程序。

白色的忧郁让我白色的思念从洁白到苍白,从苍白到空白,比空白更空白,变成深白的坦白!
2006-10-27 22:49
韩剧鼻祖
Rank: 1
等 级:新手上路
帖 子:168
专家分:0
注 册:2006-10-1
收藏
得分:0 
用指针随便指

2006-10-27 22:50
我不是郭靖
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:494
专家分:6
注 册:2006-10-4
收藏
得分:0 
以下是引用云中雾在2006-10-27 22:49:56的发言:
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void main()
{
int i,j,k;
for(j=0;j<500;j++)
{
for(k=0;k<10;k++)
{
srand( i );
i=rand();
printf("%d\t",i);
}
printf("\n");
}
}

这上产生5000个没有重复随机数的程序。

这个能保证没有重复的?


2006-10-27 23:20
maoguoqing
Rank: 6Rank: 6
来 自:重庆
等 级:贵宾
威 望:28
帖 子:2980
专家分:19
注 册:2005-12-5
收藏
得分:0 

没有想到更好的办法
int a[10001],i;
for (i=0;i<=10000;i++) a[i] = 0;//表示i没有被产生

for(i= 1;i<=5000;i++)
{
产生一个0--10000的随机数n;
while (a[n]) 产生一个0--10000的随机数n;//若n已经被产生就继续,
  a[n] = 1;//表示n被产生
}

天行健,君子以自强不息!!QQ:68660681
2006-10-28 00:34
lovelygirl
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-9-16
收藏
得分:0 
回复:云中雾
谢谢你,我先去试试啊!
2006-10-28 09:58
lovelygirl
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-9-16
收藏
得分:0 
回复:maoguoqing
恩,我回去弄弄。谢谢啦!
2006-10-28 10:00
lovelygirl
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-9-16
收藏
得分:0 
回复:韩剧鼻祖
恩,我再想想,谢谢啦
2006-10-28 10:02
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
2的程序会产生相同的数.并且也会有超过10000的数.

倚天照海花无数,流水高山心自知。
2006-10-28 12:43
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
以下是引用maoguoqing在2006-10-28 0:34:03的发言:

没有想到更好的办法
int a[10001],i;
for (i=0;i<=10000;i++) a[i] = 0;//表示i没有被产生

for(i= 1;i<=5000;i++)
{
产生一个0--10000的随机数n;
while (a[n]) 产生一个0--10000的随机数n;//若n已经被产生就继续,
  a[n] = 1;//表示n被产生
这里相当矛盾.
}

不能保证产生5000个数,因为当产生相同的数时,i也会增加.


倚天照海花无数,流水高山心自知。
2006-10-28 12:53
快速回复:[求助]:如何产生5000个0-10000的互不相同的随机数
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.059753 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved