C++ 产生不重复随机数的方法

要产生乱序的随机数字,正面来解决特别的复杂。反过来思考,假设要生成0-99,100个随机数字,且不重复。那么就相当于我们先顺序生成0-99这样一个数组,然后随机打乱就可以了

解决方法1

int main(void){
    vector numbres;
    for(int i = 0;i<100;i++)
    {
        numbres.push_back(i);
    }
    std::random_shuffle(numbres.begin(),numbres.end());
}

顺序放入,然后使用中的 random_shuffle函数利用迭代器进行打乱

解决方法2

int main(void){
    int a[100];
    for(i=0; i<=99; ++i) a[i]=i;
    for(i=99; i>=1; --i) swap(a[i], a[rand()%i]);
}

通过随机数,随机生成下标来交换

rand函数用法

#include 
int rand(void);

要取得[a,b)的随机整数,使用(rand() % (b-a))+ a;
要取得[a,b]的随机整数,使用(rand() % (b-a+1))+ a;
要取得(a,b]的随机整数,使用(rand() % (b-a))+ a + 1;
通用公式:a + rand() % n;其中的a是起始值,n是整数的范围。

你可能感兴趣的:(C++ 产生不重复随机数的方法)