sinat_29124593
小康在努力ing
采纳率25%
2016-01-21 01:42 阅读 3.3k

区间筛法求区间内素数的个数

for(ll i = 2;i*i <=b;i++) is_prime_small[i] = true;
for(ll i = 0;i <=b-a;i++) is_prime[i] = true;
for(ll i = 2;i*i <=b;i++)
{
if(is_prime_small[i])
{
for(ll j = 2*i;j*j <=b;j += i) is_prime_small[j] = false;
for(ll j = max(2LL,(a+i-1)/i)*i;j <=b;j += i) //就是这一句看不懂,还有就是2LL是啥意思~~
{
if(is_prime[j-a])
{
ans++;
is_prime[j-a] = false;
}
}
}
}

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

2条回答 默认 最新

相关推荐