如何求時間復(fù)雜度 優(yōu)先隊列時間復(fù)雜度不是nlgn嗎,插入跟刪除都得用堆排序堆排序不就是nlgn嗎?
優(yōu)先隊列時間復(fù)雜度不是nlgn嗎,插入跟刪除都得用堆排序堆排序不就是nlgn嗎?關(guān)于隊列和時間復(fù)雜度的問題?a1 O(1),因為只需刪除頭節(jié)點的下一個節(jié)點2。加入隊列:O(n),若要在隊列末尾插入新節(jié)
優(yōu)先隊列時間復(fù)雜度不是nlgn嗎,插入跟刪除都得用堆排序堆排序不就是nlgn嗎?
關(guān)于隊列和時間復(fù)雜度的問題?
a
1 O(1),因為只需刪除頭節(jié)點的下一個節(jié)點
2。加入隊列:O(n),若要在隊列末尾插入新節(jié)點,必須先遍歷隊列找到隊列的結(jié)尾,然后再插入
b)如果只有頭指針,不包括頭節(jié)點
1。退出隊列:O(n),要刪除頭節(jié)點,在更新頭指針之前必須遍歷隊列找到隊列的結(jié)尾(因為循環(huán)單鏈,如果它只是普通單鏈,那么這個操作是O(1))。Join:O(n),如果只有尾部指針
1,則與(A.2
C)相同。退出:O(1),只需刪除尾指針的下一個節(jié)點(無頭節(jié)點)或下一個節(jié)點(有頭節(jié)點)
2。Join:O(1)我們可以將Dijkstra算法的運行時間表示為邊數(shù)m和頂點數(shù)n的函數(shù)。Dijkstra算法最簡單的實現(xiàn)方法是使用鏈表或數(shù)組來存儲所有頂點的集合Q,因此在Q中提取min(Q)的操作只需要線性地搜索Q中的所有元素。因此算法的運行時間為O(N2)。對于邊數(shù)小于N2的稀疏圖,可以利用鄰接表更有效地實現(xiàn)Dijkstra算法。同時,我們需要使用二進制堆或Fibonacci堆作為優(yōu)先級隊列來尋找最小頂點(extract min)。當(dāng)使用二進制堆時,算法所需的時間是O((mn)logn)。Fibonacci堆可以稍微提高算法的性能,使算法的運行時間達到o(mnlogn)。在Dijkstra算法的基礎(chǔ)上進行一些修改,可以擴展Dijkstra算法的功能。例如,有時我們想在尋找最短路徑的基礎(chǔ)上列出一些子短路徑。為了解決這個問題,我們可以先在原圖上計算最短路徑,然后從圖中刪除路徑的一條邊,然后在剩余的子圖中重新計算最短路徑。對于原始最短路徑的每一條邊,刪除邊后可以找到子圖的最短路徑。這些路徑是排序后原圖的一系列次最短路徑。OSPF算法是Dijkstra算法在網(wǎng)絡(luò)路由中的一種實現(xiàn)。與Dijkstra算法不同的是,Bellman-Ford算法可用于支出為負的Fabian圖,只要不存在總支出為負且可從源s到達的循環(huán)(如果存在這樣的循環(huán),則不存在最短路徑,因為總支出可以通過沿循環(huán)多次而無限減少)。與最短路徑問題相關(guān)的一個問題是旅行商問題,它要求找到一條經(jīng)過所有頂點一次并最終返回到源點的最短路徑。這個問題是NP困難的;換句話說,與最短路徑問題不同,旅行商問題不可能有多項式時間算法。如果已知信息可用于估計從某一點到目標(biāo)點的距離,則可使用*算法來縮小最短路徑的搜索范圍。