我正在使用 .NET BigInteger类来执行一些数学运算。但是ModPow方法给了我错误的结果。我将它与我认为正确的 Java 进行了比较:
// C#
var a = new BigInteger(-1);
var b = new BigInteger(3);
var c = new BigInteger(5);
var x = BigInteger.ModPow(a, b, c); // (x = -1)
// Java
BigInteger a = new BigInteger("-1");
BigInteger b = new BigInteger("3");
BigInteger c = new BigInteger("5");
BigInteger x = a.modPow(b, c); // (x = 4)
它是 .NET 类中的错误还是我做错了什么?