思路
很直观的思路是我们枚举每个数判断其是不是质数。
考虑质数的定义:在大于 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;
}