我编写了以下程序,如果一个数字是素数,则返回 1,如果它是合数,则返回 0。虽然有可能错误地将复合物识别为素数。我想要关于改进(降低)以下算法的时间复杂度的建议。
int compute(int n)
{
int x;
for(int i = 1; i < 100 * sqrt(n); i++)
{
x = rand() % ((int)sqrt(n) + 1);
if(x != 0 && x != 1 && x!=n)
{
if(n % x == 0)
return 0;
}
}
return 1;
}