如何高效产生m个n范围内的不重复随机数(m

如何产生不重复的随机数?最容易想到的方法,是逐个产生这些随机数,每产生一个,都跟前面的随机数比较如果重复,就重新产生。这是个很笨的方法,且比较次数呈线性增长,越往后次数越多。其实这些比较是多余的,完全可以不进行比较,只要反过来,按顺序产生这些数,但随机产生它们的位置。例如下面产生100个100以内不重复随机数的代码:

int a[100];
for(i=0; i<=99; ++i) a[i]=i;
for(i=99; i>=1; --i) swap(a[i], a[rand()%i]);
上面这段代码只需要遍历一次就可以产生这100个不重复的随机数,它是如何做到的呢?首先第二行按顺
序用0到99填满整个数组;第三行,是随机产生从0到m-2个数组下标,把这个下标的元素值跟m-1下标的元
素值交换,一直进行到下标为1的元素。因此它只需要遍历一次就能产生全部的随机数。

1.产生一个随机数(从0到32767)
   srand((unsigned) time(NULL)); //为了提高不重复的概率
   rand(); //产生随机数
2.产生从m到n的随机数(包括m,不包括n)
   srand((unsigned) time(NULL)); //为了提高不重复的概率
   rand()%(n - m + 1) + m;                //使用时将m和n换为具体数即可


你可能感兴趣的:(C++)