zoukankan      html  css  js  c++  java
  • 产生一组不重复的随机序列

    如何产生一组不重复的随机序列,转自http://www.blogjava.net/lhulcn618/archive/2010/02/21/313522.html

    for(i = 0; i < n; i++)
    {
        x[i] = i;
    }
    for(i = 0; i < k; i++)
    {
        t = rand(i,n-1);
        swap(x[i], x[t]);
        out(x[i]);
    }

    其中,rand(a,b)产生一个 a 到 b 之间的随机,swap(a,b)交换a和b的值,out(a)把a输出作为结果。
    我们来看看这个算法的完美之处吧!

    首先,x数组里把0到n-1的所有都存储了,而最后输出的都是x数组里的值,所以满足输出的是k个0到n-1的

    然后,我们对于第 i 随机,产生一个 i 到 n-1 的下标 t ,并把x[t] 和x[i]交换,将其输出,这样每产生的都是之前没有出现过的,因为之前出现过的都在x[0] 到 x[i-1]里呢!这样就保证了输出数据的不重复性。

    最后,我们考察输出数据的“随机性”,显然,因为交换操作,使得所有没有出现过的都在x[i] 到 x[n-1]中存着呢,所以被选中的概率相等。

  • 相关阅读:
    ## 序列化和反序列化
    C#小型资源管理器
    codeforces #310 div1 B
    codeforces #310 div1 A
    BZOJ 1030 文本生成器
    BZOJ 2806 cheat
    BZOJ 2553 禁忌
    BZOJ 4199 品酒大会
    codeforces #309 div1 D
    codeforces #309 div1 C
  • 原文地址:https://www.cnblogs.com/ivywenyuan/p/4166535.html
Copyright © 2011-2022 走看看