1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
|
#include <fits.h>
#define result (rv.i4data)
Fits &primes(int k, Fits &rv) {
rv.create(k, 1, I4);
if (k == 1) {
result[0] = 2;
return rv;
}
result[0] = 2;
unsigned long n = 3;
unsigned long count = 1;
result[count] = 3;
count++;
while(count < k) {
n = n + 2;
for (int ip = 1; ip < count; ip++) {
double q = n / result[ip];
int r = n % result[ip];
if (r == 0) {
ip = count + 1; // n is not prime.
} else {
if (q <= result[ip]) { // n is prime.
result[count] = n;
count++; // compute next prime.
ip = count + 1;
}
}
}
}
return rv;
}
|