summaryrefslogtreecommitdiff
path: root/euler10.c
blob: 7d9d16b5f27c8b3c67acec5bab6f6ddd5b1a2ec6 (plain)
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
#include <stdio.h>
#define MAX 2000000

int table[MAX+1]={0};
int primes[MAX];

int main()
{
	int nPrimes,i,j;
	long long sum=0;
	for (i=2;i<=MAX;++i){
		if (table[i]==0){
			primes[nPrimes]=i;
			nPrimes++;
			sum+=i;
		}
		//sieve
		for (j=2;j<=primes[nPrimes-1];++j){
			if (i*j>MAX)
				break;
			else
				table[i*j]=1;
		}
	}
	printf("%lld\n",sum);
	return 0;
}