DAA - Biner Heap
Ada beberapa jenis heap, namun pada bab ini kita akan membahas heap biner. SEBUAHbinary heapadalah struktur data, yang terlihat mirip dengan pohon biner lengkap. Struktur data heap mematuhi properti pengurutan yang dibahas di bawah ini. Umumnya, Heap diwakili oleh sebuah array. Dalam bab ini, kami merepresentasikan heap olehH.
Karena elemen heap disimpan dalam array, dengan mempertimbangkan indeks awal sebagai 1, posisi simpul induk dari ith elemen dapat ditemukan di ⌊ i/2 ⌋. Anak kiri dan anak kananith node berada di posisi 2i dan 2i + 1.
Heap biner dapat diklasifikasikan lebih lanjut sebagai a max-heap atau a min-heap berdasarkan properti pemesanan.
Max-Heap
Di heap ini, nilai kunci node lebih besar dari atau sama dengan nilai kunci turunan tertinggi.
Karenanya, H[Parent(i)] ≥ H[i]
Min-Heap
Dalam mean-heap, nilai kunci sebuah node lebih kecil dari atau sama dengan nilai kunci dari turunan terendah.
Karenanya, H[Parent(i)] ≤ H[i]
Dalam konteks ini, operasi dasar ditunjukkan di bawah ini sehubungan dengan Max-Heap. Penyisipan dan penghapusan elemen di dalam dan dari heaps membutuhkan penataan ulang elemen. Karenanya,Heapify fungsi perlu dipanggil.
Representasi Array
Pohon biner lengkap dapat diwakili oleh larik, menyimpan elemennya menggunakan traversal urutan tingkat.
Mari kita pertimbangkan heap (seperti yang ditunjukkan di bawah) yang akan diwakili oleh sebuah array H.
Mempertimbangkan indeks awal sebagai 0, dengan menggunakan traversal urutan tingkat, elemen disimpan dalam larik sebagai berikut.
Index | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | ... |
elements | 70 | 30 | 50 | 12 | 20 | 35 | 25 | 4 | 8 | ... |
Dalam konteks ini, operasi pada heap direpresentasikan sehubungan dengan Max-Heap.
Untuk menemukan indeks induk dari suatu elemen pada indeks i, algoritma berikut Parent (numbers[], i) digunakan.
Algorithm: Parent (numbers[], i)
if i == 1
return NULL
else
[i / 2]
Indeks anak kiri dari sebuah elemen di index i dapat ditemukan menggunakan algoritma berikut, Left-Child (numbers[], i).
Algorithm: Left-Child (numbers[], i)
If 2 * i ≤ heapsize
return [2 * i]
else
return NULL
Indeks anak kanan dari sebuah elemen di indeks i dapat ditemukan menggunakan algoritma berikut, Right-Child(numbers[], i).
Algorithm: Right-Child (numbers[], i)
if 2 * i < heapsize
return [2 * i + 1]
else
return NULL