TheAlgorithms-C/project_euler/problem_7/sol.c

33 lines
590 B
C
Raw Normal View History

2019-10-01 22:21:55 +08:00
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
2019-10-01 22:21:55 +08:00
char *sieve;
size_t i;
unsigned count = 0;
size_t n = 1000000;
const unsigned target = 10001;
sieve = calloc(n, sizeof *sieve);
for (i = 2; i < n; i++)
{
if (!sieve[i])
{
size_t j;
2019-10-01 22:21:55 +08:00
count++;
if (count == target)
{
2019-10-01 22:21:55 +08:00
printf("%lu\n", i);
break;
}
for (j = i * 2; j < n; j += i)
{
2019-10-01 22:21:55 +08:00
sieve[j] = 1;
}
}
}
free(sieve);
return 0;
}