[英]What is the running time complexity of this for loop
for (int p = t; p > 0; p >>= 1) {
for (int i = 0; i < n - p; ++i) {
if ((i & p) != 0) {
sort2(a, i, i+p);
}
}
for(int q = t; q > p; q >>= 1) {
for(int i = 0; i < n- q; ++i) {
if ((i & p) != 0) {
sort2(a, i+p, i+q);
}
}
}
}
这里n
是一些正整数,并且t
大于n/2
,但不等于n
。
根据我的理解,内部for循环运行(np)
次,但是我无法弄清楚外部for循环。
我尝试找到它,如下所示:
如果t=64
且n=100
,则采用p
的二进制值,该值等于64
,因此p=1000000
2 p=1000000
底 。
我知道,每次它减少一位数,在这种情况下,它总共执行7次。 我不知道怎么算一般时间。
另外,我的理解是第三个for循环
for(int q = t; q > p; q >>= 1)
因为条件q>p
不满足,因为p=q=t
所以根本不执行。
这个对吗? 我只是从算法开始。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.