私はウィキペディアからアルゴリズムを実装しようとしてきましたが、素数として合成数を出力することはありませんが、素数の75%を合成数として出力しています。
1000までは、素数のこの出力を提供します。
3、5、7、11、13、17、41、97、193、257、641、769
私の知る限り、私の実装は擬似コードアルゴリズムとまったく同じです。私はそれを行ごとにデバッグし、期待されるすべての変数値を生成しました(私は計算機と一緒にフォローしていました)。これが私の関数です:
bool primeTest(int n)
{
int s = 0;
int d = n - 1;
while (d % 2 == 0)
{
d /= 2;
s++;
}
// this is the LOOP from the pseudo-algorithm
for (int i = 0; i < 10; i++)
{
int range = n - 4;
int a = rand() % range + 2;
//int a = rand() % (n/2 - 2) + 2;
bool skip = false;
long x = long(pow(a, d)) % n;
if (x == 1 || x == n - 1)
continue;
for (int r = 1; r < s; r++)
{
x = long(pow(x, 2)) % n;
if (x == 1)
{
// is not prime
return false;
}
else if (x == n - 1)
{
skip = true;
break;
}
}
if (!skip)
{
// is not prime
return false;
}
}
// is prime
return true;
}
助けていただければ幸いですD:
編集:これがあなたたちが提案したように編集されたプログラム全体です-そして今、出力はさらに壊れています:
bool primeTest(int n);
int main()
{
int count = 1; // number of found primes, 2 being the first of course
int maxCount = 10001;
long n = 3;
long maxN = 1000;
long prime = 0;
while (count < maxCount && n <= maxN)
{
if (primeTest(n))
{
prime = n;
cout << prime << endl;
count++;
}
n += 2;
}
//cout << prime;
return 0;
}
bool primeTest(int n)
{
int s = 0;
int d = n - 1;
while (d % 2 == 0)
{
d /= 2;
s++;
}
for (int i = 0; i < 10; i++)
{
int range = n - 4;
int a = rand() % range + 2;
//int a = rand() % (n/2 - 2) + 2;
bool skip = false;
//long x = long(pow(a, d)) % n;
long x = a;
for (int z = 1; z < d; z++)
{
x *= x;
}
x = x % n;
if (x == 1 || x == n - 1)
continue;
for (int r = 1; r < s; r++)
{
//x = long(pow(x, 2)) % n;
x = (x * x) % n;
if (x == 1)
{
return false;
}
else if (x == n - 1)
{
skip = true;
break;
}
}
if (!skip)
{
return false;
}
}
return true;
}
これで、(以前のように)3から1000までの素数の出力は次のようになります。
3、5、17、257
xが大きくなりすぎて、ごみの値になってしまうことがわかりましたが、「%n」の部分を削除するまで、それはわかりませんでした。