题目:
Count the number of prime numbers less than a non-negative number, n.
Hint:
埃拉托斯特尼筛法
wiki: http://zh.wikipedia.org/wiki/埃拉托斯特尼筛法
详细列出算法如下:
列出2以後的所有序列: 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25标出序列中的第一个素数,也就是2,序列变成: 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25将剩下序列中,劃摽2的倍数(用红色标出),序列变成: 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25如果现在这个序列中最大数小于最後一個標出的素數的平方,那么剩下的序列中所有的数都是素数,否则回到第二步。结论:去掉红色的数字,2到25之间的素数是:2 3 5 7 11 13 17 19 23。
题解:
1 public int countPrimes(int n) 2 { 3 if(n<=2) return 0; 4 boolean[] prime=new boolean[n]; 5 for(int i=2;i<n;i++) 6 { 7 prime[i]=true; 8 } 9 10 for(int i=2;i<=Math.sqrt(n-1);i++) 11 if(prime[i]) 12 { 13 for(int j=i+i;j<n;j+=i) 14 { 15 prime[j]=false; 16 } 17 } 18 19 int count=0; 20 for(int i=2;i<n;i++) 21 { 22 if(prime[i]) count++; 23 } 24 return count; 25 }
leetcode's 题解:I don't like it!
1 public int countPrimes(int n) { 2 boolean[] isPrime = new boolean[n]; 3 for (int i = 2; i < n; i++) { 4 isPrime[i] = true; 5 } 6 // Loop's ending condition is i * i < n instead of i < sqrt(n) 7 // to avoid repeatedly calling an expensive function sqrt(). 8 for (int i = 2; i * i < n; i++) { 9 if (!isPrime[i]) continue; 10 for (int j = i * i; j < n; j += i) { 11 isPrime[j] = false; 12 } 13 } 14 int count = 0; 15 for (int i = 2; i < n; i++) { 16 if (isPrime[i]) count++; 17 } 18 return count; 19 }
转载于:https://www.cnblogs.com/hygeia/p/4553645.html
相关资源:e-prime2.0