gpt4 book ai didi

c++ - 尝试计算算法的运行时间

转载 作者:太空狗 更新时间:2023-10-29 20:39:19 25 4
gpt4 key购买 nike

我有以下算法:

for(int i = n; i > 0; i--){
for(int j = 1; j < n; j *= 2){
for(int k = 0; k < j; k++){
... // constant number C of operations
}
}
}

我需要计算算法的运行时间复杂度,

我很确定外循环运行 O(n) 次,中间循环运行 O(log(n)) 次,内循环运行O(log(n)) 次,但我不太确定。

运行时间复杂度的最终结果是O(n^2),但我不知道如何。

希望有人能给我一个简短的解释,谢谢!

最佳答案

对于每个 i,第二个循环通过 2 的幂运行 j,直到它超过 n:1, 2, 4, 8 , ... , 2h,其中 h=int(log2n)。所以最内层循环的主体运行 20 + 21 + ... + 2h = 2h+ 1-1次。并且 2h+1-1 = 2int(log2n)+1-1 这是 O(n)。

现在,外层循环执行了 n 次。这使得整个事情的复杂度为 O(n*n)。

关于c++ - 尝试计算算法的运行时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28265363/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com