作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
While 循环的时间复杂度是从 2 递增到 x 其中 x^2 <= N O(lg n)
吗?有人可以解释一下吗?
代码示例如下:
public static boolean isSquare(long num) {
if ((num <= 1) && (num > 0))
return true;
long currentNumber = 2;
long currentSquare = 4;
while (currentSquare <= num) {
if (currentSquare == num)
return true;
currentNumber++;
currentSquare = currentNumber * currentNumber;
}
return false;
}
最佳答案
不,这个复杂度是O(sqrt(n))。您正在按平方改变数字,并将其与数字的平方进行比较。或者您可以将其递增 1 并与数字的平方根进行比较。
关于algorithm - 从 2 递增到 x 的 While 循环的时间复杂度,其中 x^2 <= N,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26702839/
我是一名优秀的程序员,十分优秀!