演算法 十大排序 堆排序 大頂堆

2021-10-04 14:46:07 字數 611 閱讀 8612

堆排序 ——大頂堆

大頂堆和小頂堆的差別在與大頂堆的根節點比它的子節點和葉子節點都要大,大頂堆輸出的時候是正序的而小頂堆是逆序的

同樣的也是有兩步

1,堆化

2,下調

public class _03_堆排序大頂堆 ;

sort(a);

for (int i = 0; i < a.length; i++)

} //進行堆化

public static void maxheap(int a)

} private static void maxheapfixdown(int a, int i, int n)

} //如果比它兩個孩子大就不用調整

if(a[i]>=a[max])return;

int temp=a[i];

a[i]=a[max];

a[max]=temp;

//大孩子那個位置的值發生變化,i變更大孩子的那個位置,進行遞迴調整

maxheapfixdown(a, max, n); }

public static void sort(int a)

}

}

十大排序 堆排序

堆排序屬於選擇排序 選擇排序的基本思想 每一趟 第i趟 在後面n i 1個待排序的元素中選取關鍵字最小的元素,作為有序子串行的第i個元素,直到第 n 1趟做完,待排序元素只剩下1個,就不用再選了。堆排序適合關鍵字較多的情況 n 1000 比如 在1億個數中選出前100個最大值?首先使用乙個大小為10...

十大排序演算法之堆排序

堆排序 heapsort 是指利用堆這種資料結構所設計的一種排序演算法,它是一種選擇排序,時間複雜度是o n log n 本部落格將使用最大堆來實現堆排序。對於堆的具體描述在本部落格的這篇文章 已經對最大堆這種資料結構做出了介紹,故不做重複介紹,主要介紹堆排序。以下是最大堆結構具體實現過程 impo...

十大排序演算法之 堆排序 七)

堆排序 個人感覺算是十大排序演算法中較難的一種排序演算法。1 首先了解什麼是堆,需要滿足2個條件 滿足完全二叉樹 除了最後一層,每一層都是滿的,有右子樹的前提必需有左子樹 堆分為大頂堆和小頂堆,大頂堆 每乙個節點大於其左右子結點,小頂堆同理。2 完全二叉樹的特性 完全二叉樹適用於陣列儲存 對於乙個結...