gpt4 book ai didi

c# - C# 中的 Miller Rabin 素数测试

转载 作者:行者123 更新时间:2023-11-30 20:39:56 25 4
gpt4 key购买 nike

欢迎。我正在尝试实现 MillerRabin 测试以检查给定的大数是否为素数。这是我的代码:

 public static bool MillerRabinTest(BigInteger number)
{

BigInteger d;
var n = number - 1;
var s = FindK(n, out d);

BigInteger a = 2;
BigInteger y = Calc(a, d, number); //a^d mod number
if (y != BigInteger.One && y != n)
{
for (var r = 1; r <= s - 1; r++)
{
y = Calc(y, 2, number);
if (y == 1)
return false;
}

if (y != n)
return false;
}
return true; //it is probably prime
}

它适用于小型 Bigintegers。但是如果我的程序需要评估包含超过 16 位的数字,程序就会卡住。例如,在成功检查数字是否为质数后,程序突然没有响应。我不明白这怎么可能。如果它检查了一个大数字,再次检查另一个应该没有问题。甚至调试器也没有帮助,因为 step options 消失了。如果需要,我可以分享更多功能代码。上面的函数对于小数字可以正常工作。

编辑。更改 BigInteger.ModPow 的模函数有帮助。不幸的是,现在对于更大的数字,超过 3000 位,它永远不会返回素数,这是不可能的。或者真的很难找到 prme 数字?

最佳答案

好吧,在我的工作站(Core i5 3.2GHz,IA64 .Net 4.5)上测试等于 2**3000 的数字是否为素数需要大约 5 秒>:

  public static class PrimeExtensions {
// Random generator (thread safe)
private static ThreadLocal<Random> s_Gen = new ThreadLocal<Random>(
() => {
return new Random();
}
);

// Random generator (thread safe)
private static Random Gen {
get {
return s_Gen.Value;
}
}

public static Boolean IsProbablyPrime(this BigInteger value, int witnesses = 10) {
if (value <= 1)
return false;

if (witnesses <= 0)
witnesses = 10;

BigInteger d = value - 1;
int s = 0;

while (d % 2 == 0) {
d /= 2;
s += 1;
}

Byte[] bytes = new Byte[value.ToByteArray().LongLength];
BigInteger a;

for (int i = 0; i < witnesses; i++) {
do {
Gen.NextBytes(bytes);

a = new BigInteger(bytes);
}
while (a < 2 || a >= value - 2);

BigInteger x = BigInteger.ModPow(a, d, value);
if (x == 1 || x == value - 1)
continue;

for (int r = 1; r < s; r++) {
x = BigInteger.ModPow(x, 2, value);

if (x == 1)
return false;
if (x == value - 1)
break;
}

if (x != value - 1)
return false;
}

return true;
}
}

测试和基准测试

  BigInteger value = BigInteger.Pow(2, 3217) - 1; // Mersenne prime number (2.5e968)

Stopwatch sw = new Stopwatch();

sw.Start();

Boolean isPrime = value.IsProbablyPrime(10);

sw.Stop();

Console.Write(isPrime ? "probably prime" : "not prime");
Console.WriteLine();
Console.Write(sw.ElapsedMilliseconds);

关于c# - C# 中的 Miller Rabin 素数测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33895713/

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