| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3802 人关注过本帖
标题:[求助]:如何产生5000个0-10000的互不相同的随机数
只看楼主 加入收藏
Knocker
Rank: 8Rank: 8
等 级:贵宾
威 望:47
帖 子:10454
专家分:603
注 册:2004-6-1
收藏
得分:0 
以下是引用我不是郭靖在2006-10-28 20:20:21的发言:
像你那种测试是不行的,要分析代码.
关键是这段代码产生的所有状态
for(int i=0;i<N;i++)
{
int n=rand()%N ;
int tem=a[i];
a[i]=a[n];
a[n]=tem ;
}

你把当N=3时,这段代码产生的所有状态写出来看看.共27种

无语........
俺睡觉去


九洲方除百尺冰,映秀又遭蛮牛耕。汽笛嘶鸣国旗半,哀伤尽处是重生。     -老K
治国就是治吏。礼义廉耻,国之四维。四维不张,国之不国。   -毛泽东
2006-10-28 20:23
lovelygirl
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-9-16
收藏
得分:0 
谢谢大家
真的非常感谢大家的帮助,按照maoguoqing朋友给出的程序,我整理了输出0-10000的任意互不相等的随机数的程序
#define<time.h>
#define<stdlib.h>
#define<stdio.h>
#define<math.h>
#define N 10000
#define n0 5000
#define LEN sizeof(EdgeNode)

typedef struct node
{int adj;
struct node *nex;
}EdgeNode;

void main()
{EdgeNode *Head,*H,*s;
int i,j,a[N];
int rand();
srand((unsigned int)time(NULL));
for(i=0;i<N;i++)
a[i]=0;
Head=(EdgeNode*)malloc(LEN);
Head->nex=NULL;
for(i=0;i<n0;i++)
{ j=rand()%N;
while(a[j])
j=rand()%N;
a[j]=1;
s=(EdgeNode*)malloc(LEN);
s->adj=j;
s->nex=Head->nex;
Head->nex=s;

}
H=Head; //输出
while(H->nex!=NULL)
{printf("%d\t",H->nex->adj);
H=H->nex;
}
}
2006-10-28 22:05
云中雾
Rank: 1
等 级:新手上路
威 望:1
帖 子:168
专家分:3
注 册:2005-12-30
收藏
得分:0 

#include <time.h>
#include <stdlib.h>
#include <stdio.h>
#include <math.h>
#define N 10000
#define n0 5000
#define LEN sizeof(EdgeNode)

typedef struct node
{int adj;
struct node *nex;
}EdgeNode;

void main()
{EdgeNode *Head,*H,*s;
int i,j,a[N];
int rand();
srand((unsigned int)time(NULL));
for(i=0;i<N;i++)
a[i]=0;
Head=(EdgeNode*)malloc(LEN);
Head->nex=NULL;
for(i=0;i<n0;i++)
{ j=rand()%N;
while(a[j])
j=rand()%N;
a[j]=1;
s=(EdgeNode*)malloc(LEN);
s->adj=j;
s->nex=Head->nex;
Head->nex=s;

}
H=Head;
while(H->nex!=NULL)
{printf("%d\t",H->nex->adj);
H=H->nex;
}
}

楼上的,程序能运行不?注意一下红色部分。


白色的忧郁让我白色的思念从洁白到苍白,从苍白到空白,比空白更空白,变成深白的坦白!
2006-11-01 16:37
lovelygirl
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-9-16
收藏
得分:0 
回复:(云中雾)
呵呵,谢谢。写错了。前面的应该为你的红色部分所指。
2006-11-20 16:48
快速回复:[求助]:如何产生5000个0-10000的互不相同的随机数
数据加载中...
 
   



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

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