主要就是素数筛选,记录下special primes;和一个二分查找;数组的大小是经过计算后开的,以免大了浪费空间,小了会WA;
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std;
bool b[1000005];
int ss[380005],num,temp,n;
int speci[8000];
void _prime()
{
for(int i=2;i<=1000000;i++)
{
if(!b[i])
{
for(int j=i+i;j<=1000000;j+=i)
b[j]=true;
ss[++num]=i;
}
}
}
void _special()
{
for(int i=2;i<=num;i++)
if(!b[i]) speci[++temp]=ss[i];
}
void _find()
{
int L=1;
int R=7702;
if(n<speci[1]) printf("-1\n");
else
{
while(L<R)
{
int mid=(L+R)/2;
if(R==L+1)
{
if(speci[R]<=n) printf("%d\n",speci[R]);
else printf("%d\n",speci[L]);
return ;
}
if(speci[mid]>n) R=mid;
else L=mid;
}
}
}
int main()
{
_prime();
_special();
while(~scanf("%d",&n)) _find();
return 0;
}