在PHP中使用大量数字

nic*_*ckf 53 php bignum

要使用大数(100,000+)的Fermat Primality Test时需要使用模幂运算,需要进行一些非常大的计算.

当我乘以两个大数(例如:62574和62574)时,PHP似乎将结果转换为浮点数.获取模数值会返回奇怪的值.

$x = 62574 * 62574;
var_dump($x);          // float(3915505476) ... correct
var_dump($x % 104659); // int(-72945)  ... wtf.
Run Code Online (Sandbox Code Playgroud)

有没有办法让PHP正确执行这些计算?或者,是否有另一种方法可以找到适用于大数的模数值?

Iva*_*tov 53

出于某种原因,PHP中有两个标准库处理任意长度/精度数:BC MathGMP.我个人更喜欢GMP,因为它更新鲜,并且具有更丰富的API.

基于GMP,我实施了Decimal2类来存储和处理货币金额(如100.25美元).很多 mod计算没有任何问题.测试了非常大的数字.

  • GMP 仅适用于整数,而 BC Math 则适用于浮点数。 (3认同)
  • 这不是一个很好的答案,因为没有提供任何示例。 (2认同)

小智 51

用这个

 $num1 = "123456789012345678901234567890";
 $num2 = "9876543210";
 $r    = mysql_query("Select @sum:=$num1 + $num2");
 $sumR = mysql_fetch_row($r);
 $sum  = $sumR[0];
Run Code Online (Sandbox Code Playgroud)

  • Zomg,这既是一个令人敬畏的,也是一个非常丑陋的回应. (111认同)
  • 抱歉,SQL服务器是SQL服务器,而不是计算器. (43认同)
  • 你是认真的吗? (7认同)
  • @Namek鉴于Delphi的受欢迎程度,我怀疑过去10年中有没有人. (6认同)
  • @GordonM,您是否从未在Delphi中使用ListBox对字符串进行排序? (5认同)
  • 将问题转移到数据库(最终也会失败),并且在此过程中创建 SQL 注入漏洞,这是下一个级别的白痴……即使这个答案已经有 9 年历史了。 (4认同)

Owe*_*wen 20

你看看了bcmod()吗?php在32位平台上有超过2 ^ 31 - 1的整数问题.

var_dump(bcmod("$x", '104659') ); // string(4) "2968"
Run Code Online (Sandbox Code Playgroud)