码迷,mamicode.com
首页 > 其他好文 > 详细

[LeetCode] Count Primes

时间:2015-07-13 17:45:04      阅读:97      评论:0      收藏:0      [点我收藏+]

标签:

Description:

Count the number of prime numbers less than a non-negative number, n.

思路:一个一个判断,

时间复杂度:O(n^2)

代码:TLE

public class Solution {
    public int countPrimes(int n) {
        int cnt=0;
        while(n>0)
        {
            if(isPrime(n))
                cnt++;
            n--;
        }
        return cnt; 
    }
    public boolean isPrime(int k)
    {
        if(k==1 || k==2) return true;
        for(int i=2;i<=Math.sqrt(k);i++)
        {
            if(k%i==0)
            {
                return false;
            }
        }
        return true;
    }
}

优化:

创建一个长度为N的数组,从2开始, 把其倍数小于N的都删掉.

        boolean [] a=new boolean[n];
        for(int i=2;i*i<n;i++)
        {
            if(!a[i])
            {
                for(int j=i;j*i<n;j++)
                {
                    a[j*i]=true;
                }
            }
        }
        int cnt=0;
        for(int i=2;i<n;i++)
        {
            if(!a[i])
                cnt++;
        }
        return cnt;

 

[LeetCode] Count Primes

标签:

原文地址:http://www.cnblogs.com/maydow/p/4643068.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!