- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想将一个长序列(比如它有超过 10000 个元素)洗牌很多次(比如 10000)。阅读时Python Random documentation ,我发现了以下内容:
Note that even for small len(x), the total number of permutations of x can quickly grow larger than the period of most random number generators. This implies that most permutations of a long sequence can never be generated. For example, a sequence of length 2080 is the largest that can fit within the period of the Mersenne Twister random number generator
我有两个组(可能更多),每个组都有很多值。我要洗牌的顺序是所有可用值的列表,与组无关。我担心的是,该注释暗示 random.shuffle() 函数可能无法提供我需要的洗牌。
我已经考虑了一些解决方法:
我的替代方案有帮助吗?
非常感谢!
最佳答案
嗯 10,000! ~= 10^36,000
这是很多可能的排列。您能做的最好的事情就是深入研究您的操作系统或硬件如何累积“真正随机”的位。然后,您可以等待 ~120,000 位您可以接受的随机性,然后使用算法在给定随机 n 的情况下生成输入列表的第 n 个排列。
关于python - 在 Python 中将一长串洗牌次数甚至更长,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46859257/
我正在尝试创建一个程序,其中字符串的前三个字符重复给定次数,如下所示: foo('Chocolate', 3) # => 'ChoChoCho' foo('Abc', 3) # => 'AbcAbcA
我有以下字符串: std::string str = "Mode:AAA:val:101:id:A1"; 我想分离一个位于 "val:" 和 ":id" 之间的子字符串,这是我的方法: std::st
DNA 字符串可以是任意长度,包含 5 个字母(A、T、G、C、N)的任意组合。 压缩包含 5 个字母(A、T、G、C、N)的 DNA 字母串的有效方法是什么?不是考虑每个字母表 3 位,我们可以使用
是否有一种使用 levenstein 距离将一个特定字符串与第二个较长字符串中的任何区域进行匹配的好方法? 例子: str1='aaaaa' str2='bbbbbbaabaabbbb' if str
使用 OAuth 并使用以下函数使用我们称为“foo”(实际上是 OAuth token )的字符串加密 key public function encrypt( $text ) { // a
我是一名优秀的程序员,十分优秀!