O(nlogn)算法:
memset(vis,0,sizeof(vis));
for(int i=2;i<=n;i++)
for(int j=2*i;j<=n;j+=i) vis[j]=1;
优化代码:
memset(vis,0,sizeof(vis));
for(int i=2;i<=sqet(m+0.5);i++)
if(!vis[i]) for(int j=i*i;j<=n;j+=i) vis[j]=1;
O(nlogn)算法:
memset(vis,0,sizeof(vis));
for(int i=2;i<=n;i++)
for(int j=2*i;j<=n;j+=i) vis[j]=1;
memset(vis,0,sizeof(vis));
for(int i=2;i<=sqet(m+0.5);i++)
if(!vis[i]) for(int j=i*i;j<=n;j+=i) vis[j]=1;