跳跃数字抽签h

补充:

楼主,我的算法你根本没看懂,我保证不会有重号。

我的算法是这样的:先把1~64排序写成一个序列,然后遍历一次,每次随机找个地方和它交换,达到随机排列的效果。

这是一个很常用的生成随机排列的算法,是一个很基础很简单的程序,不会错。

不信你就跑一跑看结果是不是重复~ ~ ~

我知道你理解的是另一种算法,随机产生一个数然后判断是否出现过然后填入数组。我的算法时间复杂度为O(n),是比你理解的更高效的生成随机序列的算法。好好学习~

=====================================

楼上的baiddd程序是错误的。

楼主要的是随机数。你的程序能生成随机数吗?

Rand()一般用于生成随机数。

下面是我的程序,楼主可以运行看看,生成一个1到64的随机数组。

# include & ltstdio.h & gt

# include & lttime.h & gt

# include & ltstdlib.h & gt

int main()

{

字符编号[64];

int I;

int a,tmp

for(I = 0;我& lt64;i++)num[I]= I+1;

srand(time(0));

for(I = 0;我& lt64;i++)

{

a = rand()% 64;

tmp = num[I];

数字[I]=数字[a];

num[a]= tmp;

}

for(I = 0;我& lt64;i++) printf("%d ",num[I]);

printf(" \ n ");

返回0;

}