2020年12月3日leetcode每日一题

思路
很直观的思路是我们枚举每个数判断其是不是质数。

考虑质数的定义:在大于 11 的自然数中,除了 11 和它本身以外不再有其他因数的自然数。因此对于每个数 xx,我们可以从小到大枚举 [2,x-1][2,x−1] 中的每个数 yy,判断 yy 是否为 xx 的因数。但这样判断一个数是否为质数的时间复杂度最差情况下会到 O(n)O(n),无法通过所有测试数据。

考虑到如果 yy 是 xx 的因数,那么 \frac{x}{y}
y
x

也必然是 xx 的因数,因此我们只要校验 yy 或者 \frac{x}{y}
y
x

即可。而如果我们每次选择校验两者中的较小数,则不难发现较小数一定落在 [2,\sqrt{x}][2,
x

] 的区间中,因此我们只需要枚举 [2,\sqrt{x}][2,
x

] 中的所有数即可,这样单次检查的时间复杂度从 O(n)O(n) 降低至了 O(\sqrt{n})O(
n

)。

作者:LeetCode-Solution
链接:https://leetcode-cn.com/problems/count-primes/solution/ji-shu-zhi-shu-by-leetcode-solution/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
代码

int countPrimes(int n){
    if(n==0||n==1) return 0;
    int count=0;
    for(int i=2;i<n;i++)
    {
        int j=2;
        for(j;j*j<=i;j++)
        {
            if(i%j==0)
            {
                break;
            }
        }
        if(j*j>i)
        {
            count++;
        }
    }
    return count;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值