mergesort

    0熱度

    1回答

    我不太明白爲什麼要用自頂向下的合併排序對長度爲N的數組進行排序,它只需要6NlogN數組訪問。 (每級需要6N,高度爲LGN,所以它的6NlgN總共) 每個合併使用至多6N數組訪問(2N用於複製,2N爲回遷,並且至多2N用於比較) 是不是將N個元素複製到輔助數組中並將其複製回原始數組,即2N?什麼是2N「退回」? 這個問題實際上來自算法Mergesort中的Progosition G。我爲此想。

    0熱度

    1回答

    我正在嘗試編寫一個函數,它將一個數字作爲輸入,並以排序順序輸出未排序列表中的前一個和下一個數字。例如,如果列表是[29,1,49,8],調用函數(8)應該返回[1,29] 只有平均複雜度最小的可行解決方案是通過排序,還有其他方法,平均複雜性?該列表是隨機生成的固定大小的100

    0熱度

    1回答

    我看到一些帖子,瞭解歸併排序。我知道遞歸方法維護堆棧來保存值。 (我明白的是return語句的結果將是在棧) private int recur(int count) { if (count > 0) { System.out.println(count); return count + recur(--count); // this value will be

    0熱度

    2回答

    1歸併函數被調用,直到如果條件滿足 現在,據我所知,如果IF-conditon不滿足,則它的身體就不會執行 餘米無法理解後if-conditon第2個mergesort函數的不滿意度是否會被調用?它是如何發生的? PLZ詳細講解 mergesort (int*a,int*b,int low,int high) { int pivot if(low<high)

    0熱度

    1回答

    我知道這個算法的時間複雜度爲o(nlogn),但是如果我們只談合併步驟,那麼這個算法仍然是o(nlogn)嗎?或者它減少到o(logn)?我相信第二個答案是答案,但由於我們仍然需要觸摸陣列中的每個元素,我懷疑複雜性仍然是一樣的 乾杯!

    2熱度

    2回答

    對於合併排序和快速排序,我試圖想出最糟糕的情況。如果我是正確的,當所有東西都排序後,合併排序的最壞情況O(nlogn)。快速排序最糟糕的情況是當數據透視表處於最不理想的位置,並且數組被排序,所以它變成了O(n^2)。我想知道這是否是正確的,所以如果不是,請糾正。 我真正的問題是如果快速排序的樞軸位於數組的中間,那麼數組必須看起來像是爲了O(n^2)?

    0熱度

    1回答

    public class MergeSort { public static double[] MergeSort(double[] a){ if(a.length < 1){ return new double[0]; } else if(a.length == 1){ return a; } else{

    4熱度

    2回答

    我正在學習如何實現mergesort的入門C++課程。我想通過在代碼中的每一步走我自己,但有一件被絆倒了我,讓 1. void mergeSort(int *x, int len){ 2. if (len>1){ 3. int newLen=len/2; 4. mergeSort(x, newLen); 5. mergeSort(x+newLen,len-newLen); 6. int

    -1熱度

    2回答

    下面的代碼是一個合併排序程序,我需要有關評論的部分更多的解釋。我不確定它是否用於添加數組的其餘元素,如果是這樣,那麼數組後半部分的剩餘元素呢? public class MyMergeSort { private int[] array; private int[] tempMergArr; private int length; public stat

    0熱度

    1回答

    我目前正在使用一個漂亮的標準合併排序文件,但我遇到了一些問題。我對數據結構相當陌生,所以不能完全理解發生了什麼。任何提示都會很好。謝謝。 下面是代碼 #include <stdio.h> #include <stdlib.h> typedef struct CELL *LIST; struct CELL { int element; LIST next; } LI