题意 给定n k 求小于等于n 的数能拆成两个相邻的素数和1的和 这样的数的个数是否大于等于k
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
bool isprime[1010];
int prime[1010],sum_prime;
void get_prime()
{
sum_prime = 0;
memset(isprime,1,sizeof(isprime));
isprime[1] = 0;
for(int i = 2; i < 1010; i ++)
{
if(isprime[i] == 1)
{
prime[sum_prime ++] = i;
for(int j = i+i; j < 1010; j += i)
{
isprime[j] = 0;
}
}
}
}
int main()
{
get_prime();
int n,k;
while(cin>>n>>k)
{
int ans = 0,tmp;
for(int i = 1;prime[i] <= n;i ++)
{
tmp = prime[i] + prime[i-1] + 1;
if(isprime[tmp] && tmp <= n)
ans ++;
}
if(ans >= k)
cout<<"YES"<<endl;
else
cout<<"NO"<<endl;
}
return 0;
}