about summary refs log tree commit diff
path: root/ntu/ngto4.c
blob: 02237b62b37678cdcf9b9cbe6b4052229d215d1a (plain) (blame)
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
#include <stdio.h>
#include <math.h>

#define idx(n) (n - 1) / 2 - 1

long primes[1000000];

int main()
{
	long i, j;
	char pdict[500001] = {[0 ... 500000] = 1};
	for (i = 3; i < 1000; i += 2)
		if (pdict[idx(i)])
			for (j = i * i; j < 1000000; j += i * 2)
				pdict[idx(j)] = 0;

	primes[0] = 2;
	j = 0;
	for (i = 3; i < 1000000; i += 2)
		if (pdict[idx(i)])
			primes[++j] = i;

	printf("%ld ", primes[78497]);
	printf("\n%ld\n", j);

	return 0;
}