区间质数统计

这段代码采用埃氏筛法预处理质数,并计算给定区间[L, R]内(2 ≤ a < b ≤ 10^9,b - a ≤ 1000000)的质数个数。主要涉及算法优化和大整数处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

计算 区间[a,b]的所有质数个数
2≤a<b≤10^9,b-a<=1000000

import java.util.Scanner;

public class Main {
    static final int MAX=1000000+10;
    static final boolean[] flag=new boolean[MAX];
    static final int[] prime=new int[MAX];
    static final boolean[] vis=new boolean[MAX];
    static int cnt=-1;
    static {//埃氏筛法
        for(int i=2;i*i<=50000;i++){
            if(!vis[i]){
                for(int j=i*i;j<=50000;j+=i)
                    vis[j]=true;
            }
        }
        for(int i=2;i<=50000;i++)
            if(!vis[i])
                prime[++cnt]=i;
    }
    public static void main(String[] args) {
        Scanner cin=new Scanner(System.in);
        int L=cin.nextInt();
        int R=cin.nextInt();
        System.out.println(Prime(L,R));
    }
    static int Prime(int L,int R){
        for(int i=0;i<=cnt;i++){
            for(int j=Math.max(2,(L-1)/prime[i]+1)*prime[i];j<=R;j+=prime[i]){
                if(j-L>=0)
                    flag[j-L]=true;
            }
        }
        int ans=0;
        for(int i=L;i<= R;i++)
            if(!flag[i-L])
                ++ans;
        return ans;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值