Pagini recente » Cod sursa (job #703260) | Cod sursa (job #253289) | Cod sursa (job #1209678) | Cod sursa (job #2218433) | Cod sursa (job #756569)
Cod sursa(job #756569)
//metoda gandita un pic
#include <iostream>
#include <fstream>
using namespace std;
char prim[200005];
void init(int x) {
int i;
for(i=1; i<=2*x; i++) {
prim[i]='1';
}
prim[1]='1';
}
int main() {
ifstream f("sum.in");
ofstream g("sum.out");
int n, x, t, i, j, k, s;
f>>n;
for(t=1; t<=n; t++) {
f>>x;
init(x); //le face pe toate 1;
s=0;
for(i=2; i<=x; i++) {
if(x%i==0) prim[i]='-';
}
for(i=1; i<2*x; i++) {
if(prim[i]=='-')
for(j=i; j<=2*x; j+=i) prim[j]='0';
}
// if(x%2==0) for(i=2; i<=2*x; i+=2) prim[i]=0;
for(i=1; i<=2*x; i++)
if(prim[i]=='1') s+=i;
g<<s<<"\n";
}
f.close();
g.close();
return 0;
}