python - 将一个巨大的数字乘以 random() (Python)

标签 python optimization largenumber

问题: 生成大型二进制字符串(长度超过 2000)。 Action 要快,因为这个 generateRandom() 函数将在算法中被调用 300,000 次。

尝试的解决方案:生成 3 或 4 个二进制数并将它们全部附加在一起 ​​500 次。这太慢了。

调用 random.random() 并将其乘以一个巨大的数字。一次转换为二进制并完成。这适用于较小的数字,但由于二进制字符串必须具有一定长度,因此转换为二进制的数字必须非常巨大 (2 ** len(binString))。

当前代码(适用于较小的数字):

binaryRepresentation = ''

binaryRepresentation += bin(int(random.random() * (2 ** binLength)))[2:].zfill(binLength)

我需要帮助修复的错误: 此调用会抛出一个带有大数字的“long int too large to convert to float”。有没有办法使整个算法更高效或使这个大数字可转换为 float ?

谢谢!

最佳答案

衡量它是否足够快以达到您的目的,“随机性”可能会随着您调用它的次数而减少:os.urandom(250) .它产生一个二进制字符串,也称为字节。

为避免“long int too large to convert to float”错误,请勿使用 float 。

如果您需要一个具有 k 个随机位的整数而不是二进制字符串:

import random
r = random.SystemRandom()

n = r.getrandbits(2000) # uses os.urandom() under the hood

获取“0”和“1”的字符串:

k = 2000
binstr = "{:0{}b}".format(r.getrandbits(k), k)

注意:如果未使用 getrandbits,则不能对大数使用 randint/randrange:

import random

class R(random.Random):
    def random(self): # override random to suppress getrandbits usage
        return random.random()

r = R()
r.randrange(2**2000) # -> OverflowError: long int too large to convert to float

b2a_bin

b2a_bin() extension允许直接从字节串创建二进制字符串(“01”),而无需创建中间 Python 整数。它比纯 Python 类似物快 3-20 倍:

def b2a_bin_bin(data):
    return bin(int.from_bytes(data, 'big', signed=False)
               )[2:].zfill(len(data)*8).encode('ascii', 'strict')

def b2a_bin_format(data):
    n = int.from_bytes(data, 'big', signed=False)
    return "{:0{}b}".format(n, len(data)*8).encode('ascii', 'strict')

用法:

>>> import os
>>> from b2a_bin import b2a_bin
>>> b2a_bin.b2a_bin(b'\x0a')
b'00001010'
>>> b2a_bin(os.urandom(5))
b'1001111011000011111001110010000101111010'

关于python - 将一个巨大的数字乘以 random() (Python),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12161988/

相关文章:

python - 来自 pandas 数据框的不同大小、标记和颜色的散点图

python - 如何使用 discord.py 在音乐机器人上获得最佳音频质量?

php - 用于大型数组的 php in_array 替代方案,用于避免重复条目

c++ - const 右值引用是否允许对编译器进行额外优化?

python - 为什么 python 不能在所有领域处理非常大的数字?

python - 使用 python 的 BigQuery 外部表

python - 超出最大递归深度

c - 使用单个变量/寄存器存储 2 个值(并通过位掩码和/或字长的特定 CPU 指令读取它们)

three.js - 我可以提高 THREE.js 中的矢量精度吗?

java - 如何使用大值格式化程序设置自定义后缀