题解 | #Prime Number#

Prime Number

http://www.nowcoder.com/practice/c5f8688cea8a4a9a88edbd67d1358415

#include<iostream>
#include<cstdio>
#include<vector>
using namespace std;
const int MAXN=1e5+1e4;
bool isPrime[MAXN];
vector<int> Prime;
void Select(){
    for(int i=0;i<MAXN;++i){
        isPrime[i]=true;
    }
    isPrime[0]=isPrime[1]=false;
    for(int i=2;i<MAXN;++i){
        if(isPrime[i]){
            Prime.push_back(i);
            for(int j=i*i;j<MAXN;j+=i){
                isPrime[j]=false;
            }
        }
    }
}
int main(){
    int n;
    Select();
    while(scanf("%d",&n)!=EOF){
        printf("%d\n",Prime[n-1]);
    }
    return 0;
}

全部评论

相关推荐

评论
4
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务