第21281题 单选
求给定C++素数筛程序的时间复杂度

下面C++程序的时间复杂度为( )。

int  primes [MAXP] ,  num  =  0 ;
bool  isPrime [MAXN]  =  {false} ; 
void  sieve()  {    
    for  (int  n  =  2;  n  <=  MAXN ;  n++)  {        
        if  (!isPrime [n])
            primes [num++]  =  n ;        
        for  (int  i  =  0 ;  i  <  num  &&  n  *  primes [i ]  <=  MAXN ;  i++)  {             
            isPrime [n  *  primes [i ]]  =  true ;            
            if  (n  %  primes [i ]  ==  0 )                
                break;        
    }
}
A

O(n log n)

B

O(n log log n)

C

O(n)

D

O(log n)

提交0次 正确率0.00%
答案解析