2010-11-21 5 views
4

Mögliche Duplizieren:
Fastest algorithm for primality testBeispielcode für schnelle Primtests in C#

eine Referenz schätzen würde Code für schnelle Primtests in C# probieren, vorzugsweise BigInteger oder andere variable Größe mit Art.

+0

Nun, ich verstehe, was sind die schnellsten Algorithmen zur Verfügung, das heißt AKS, Miller-Rabin, etc. Ich für eine effiziente Implementierung in C# suchen. –

+0

In der Zwischenzeit habe ich gefunden: http://www.emilstefanov.net/Projects/GnuMpDotNet/. Sieht vielversprechend aus. –

+0

das folgende ist ziemlich schneller als der Miller Rabin Test in der Antwort gegeben http://StackOverflow.com/a/33627100/44080 –

Antwort

16

Dies ist ein Miller Rabin Test in C#:

bool MillerRabin(ulong n) 
    { 
     ulong[] ar; 
     if (n < 4759123141) ar = new ulong[] { 2, 7, 61 }; 
     else if (n < 341550071728321) ar = new ulong[] { 2, 3, 5, 7, 11, 13, 17 }; 
     else ar = new ulong[] { 2, 3, 5, 7, 11, 13, 17, 19, 23 }; 
     ulong d = n - 1; 
     int s = 0; 
     while ((d & 1) == 0) { d >>= 1; s++; } 
     int i, j; 
     for (i = 0; i < ar.Length; i++) 
     { 
      ulong a = Math.Min(n - 2, ar[i]); 
      ulong now = pow(a, d, n); 
      if (now == 1) continue; 
      if (now == n - 1) continue; 
      for (j = 1; j < s; j++) 
      { 
       now = mul(now, now, n); 
       if (now == n - 1) break; 
      } 
      if (j == s) return false; 
     } 
     return true; 
    } 

    ulong mul(ulong a, ulong b, ulong mod) 
    { 
     int i; 
     ulong now = 0; 
     for (i = 63; i >= 0; i--) if (((a >> i) & 1) == 1) break; 
     for (; i >= 0; i--) 
     { 
      now <<= 1; 
      while (now > mod) now -= mod; 
      if (((a >> i) & 1) == 1) now += b; 
      while (now > mod) now -= mod; 
     } 
     return now; 
    } 

    ulong pow(ulong a, ulong p, ulong mod) 
    { 
     if (p == 0) return 1; 
     if (p % 2 == 0) return pow(mul(a, a, mod), p/2, mod); 
     return mul(pow(a, p - 1, mod), a, mod); 
    } 
+0

Saeed: Vielen Dank. Ich habe den Code konvertiert, um den BigInteger-Typ zu verwenden. Funktioniert super und extrem schnell. –

+0

Vielen Dank! – amuliar

+0

Das ist schön. Ich habe mich gefragt, wie Sie auf die "ar" -Werte gekommen sind? Irgendwelche Referenzen, die ich nachschlagen könnte? – tweaksp

Verwandte Themen