[英]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.