gpt4 book ai didi

c++ - GMP-无模功率

转载 作者:太空狗 更新时间:2023-10-29 20:15:22 27 4
gpt4 key购买 nike

我正在尝试将任意大的数字提高到任意大的幂。据我所知,GMP 有一个函数可以执行此操作,但对结果应用模,还有一个函数可以让我将任意数字提高到 unsigned int 指数。有解决办法吗?

最佳答案

and a function that lets me raise an arbitrary number to an unsigned int exponent

它是一个 unsigned long int 指数,所以如果你在一个 unsigned long 是 64 位(或更多)的系统上,这将使你超出可用内存 future 几年(2^(2^64-1) 需要几个 EB 存储空间)。

如果您使用的是 32 位 unsigned long 系统,您可以将指数分成两部分,

if (exponent >= (1u << 31)) {
mpz_pow_ui(base, base, exponent >> 31);
mpz_pow_ui(base, base, 1u << 31);
}
mpz_pow_ui(base, base, exponent & ((1u << 31) - 1));

这很有可能需要比您拥有的更多的内存。

另一个问题是 GMP 使用 int 来计算肢体数量,因此通常您不能使用超过 (2^31 - 1)*BITS_PER_LIMB 位(BITS_PER_LIMB 通常是 32 位或 64 位,具体取决于平台)。

如果您认为您需要 a^b,其中 a > 1b 不适合 unsigned long ( long),无论如何你都会遇到 GMP 和你的内存问题。

关于c++ - GMP-无模功率,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13345126/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com