Pagini recente » Cod sursa (job #1122922) | Cod sursa (job #1165106) | Cod sursa (job #1728193) | Cod sursa (job #2572220) | Cod sursa (job #167558)
Cod sursa(job #167558)
#include<stdio.h>
#include<string.h>
//#include<timer.h>
#define N 1000000
//using namespace std;
char v[N+1];
int n,x;
int vect[N];
/*void ciur1(){
int i,j;
memset(v,0,N);
v[0]=v[1]=1;
for (i=2;i<=N;++i)
if (v[i]==0){
for (j=i+i;j<=N;j+=i)
v[j]=1;
}
}
void ciur2(){
int i,j;
memset(v,0,N);
v[0]=1;v[1]=1;
for (i=4;i<=N;i+=2)
v[i]=1;
for (i=3;i<=N;i+=2)
if (v[i]==0)
for (j=i+i;j<=N;j+=i)
v[j]=1;
}*/
int ciur(){
int i,j,nr=1;
//memset(v,0,n);
v[0]=v[1]=1;vect[1]=2;x=1;
for (i=4;i<=n;i+=2)
v[i]=1;
for (i=3;i<=n;i+=2)
if (v[i]==0){
++x;vect[x]=i;
++nr;
for (j=i*i;j<=n;j+=i)
v[j]=1;
}
return nr;
}
int main(){
//timer t;
int i;
freopen("ciur.in","r",stdin);
freopen("ciur.out","w",stdout);
scanf("%d",&n);
printf("%d\n",ciur());
return 0;
}