Feb 17, 2012 at 10:33pm UTC  
Hello there. Im working on a euler project problem. I'm attempting to use the "sieve of eratosthenes" (on wikipedia) pseudo code. Here's my interpretation:
1//euler prob_10 
#include <iostream> 
using  namespace  std;
//answer should be: 142913828922 
int  main(){
	int  i,j,sum=0,n=2000000;
	bool  list[n];
	list[0]=false ;
	list[1]=false ;
	for (i=2;i<n;i++)
		list[i]=true ;
		
	for (i=2;i<n/2;i++){
		if (list[i]==true )
			for (j=2*i;j<=n;j+=i)
				list[j] = false ;
	}
	for (i=2;i<=n;i++){
		if (list[i]==true )
			sum+=i;
	}
	cout<<sum<<endl;
	return  0;
}
when i run a smaller max range like 10 in for n, I get the correct answer. But not with 2000000. Any help? Thanks in advance!!
 
Last edited on Feb 17, 2012 at 10:42pm UTC  
 
Feb 17, 2012 at 10:43pm UTC  
bool  list[n];