第20730题 单选
下列关于两种求解最大公约数的C++函数的说法,错误的是?
int gcd0(int big, int small) {    
    if (big < small) {        
        swap(big, small);    
    }    
    if (big % small == 0) {        
        return small;    
    }    
    return gcd0(small, big % small);
}
int gcd1(int big, int small) {    
    if (big < small) {        
        swap(big, small);    
    }    
    for (int i = small; i >= 1; --i) {        
        if (big % i == 0 && small % i == 0)        
        return i;    
    }    
    return 1;
}
A

gcd0() 函数的时间复杂度为O(log n)

B

gcd1() 函数的时间复杂度为O(n)

C

一般说来,gcd0() 的效率高于 gcd1()

D

gcd1() 中的代码 for (int i = small; i >= 1; --i) 应该修改为 for (int i = small; i > 1; --i)