Python - Tumpukan
Heap adalah struktur pohon khusus di mana setiap simpul induk kurang dari atau sama dengan simpul anaknya. Kemudian disebut Min Heap. Jika setiap node induk lebih besar dari atau sama dengan node turunannya maka disebut max heap. Hal yang sangat berguna adalah mengimplementasikan antrian prioritas dimana item antrian dengan bobot lebih tinggi diberikan prioritas lebih dalam pemrosesan. Diskusi mendetail tentang heaps tersedia di situs web kami di sini. Silakan pelajari terlebih dahulu jika Anda baru mengenal struktur data head. Pada bab ini kita akan melihat implementasi struktur data heap menggunakan python.
Buat Heap
Heap dibuat dengan menggunakan pustaka bawaan python bernama heapq. Perpustakaan ini memiliki fungsi yang relevan untuk melakukan berbagai operasi pada struktur data heap. Di bawah ini adalah daftar dari fungsi-fungsi ini.
- heapify - Fungsi ini mengubah daftar biasa menjadi heap. Dalam tumpukan yang dihasilkan, elemen terkecil didorong ke posisi indeks 0. Namun elemen data lainnya belum tentu diurutkan.
- heappush - Fungsi ini menambahkan elemen ke heap tanpa mengubah heap saat ini.
- heappop - Fungsi ini mengembalikan elemen data terkecil dari heap.
- heapreplace - Fungsi ini menggantikan elemen data terkecil dengan nilai baru yang disediakan dalam fungsi.
Membuat Heap
Heap dibuat hanya dengan menggunakan daftar elemen dengan fungsi heapify. Dalam contoh di bawah ini kami menyediakan daftar elemen dan fungsi heapify mengatur ulang elemen-elemen yang membawa elemen terkecil ke posisi pertama.
import heapq
H = [21,1,45,78,3,5]
# Use heapify to rearrange the elements
heapq.heapify(H)
print(H)
Ketika kode di atas dijalankan, itu menghasilkan hasil sebagai berikut -
[1, 3, 5, 78, 21, 45]
Memasukkan ke heap
Memasukkan elemen data ke heap selalu menambahkan elemen pada indeks terakhir. Tapi Anda bisa menerapkan fungsi heapify lagi untuk membawa elemen yang baru ditambahkan ke indeks pertama hanya jika nilainya terkecil. Dalam contoh di bawah ini kami memasukkan angka 8.
import heapq
H = [21,1,45,78,3,5]
# Covert to a heap
heapq.heapify(H)
print(H)
# Add element
heapq.heappush(H,8)
print(H)
Ketika kode di atas dijalankan, itu menghasilkan hasil sebagai berikut -
[1, 3, 5, 78, 21, 45]
[1, 3, 5, 78, 21, 45, 8]
Menghapus dari heap
Anda dapat menghapus elemen pada indeks pertama dengan menggunakan fungsi ini. Pada contoh di bawah ini, fungsi akan selalu menghapus elemen pada posisi indeks 1.
import heapq
H = [21,1,45,78,3,5]
# Create the heap
heapq.heapify(H)
print(H)
# Remove element from the heap
heapq.heappop(H)
print(H)
Ketika kode di atas dijalankan, itu menghasilkan hasil sebagai berikut -
[1, 3, 5, 78, 21, 45]
[3, 21, 5, 78, 45]
Mengganti di Heap
Fungsi heapreplace selalu menghapus elemen terkecil dari heap dan menyisipkan elemen baru yang masuk di suatu tempat yang tidak diperbaiki oleh urutan apa pun.
import heapq
H = [21,1,45,78,3,5]
# Create the heap
heapq.heapify(H)
print(H)
# Replace an element
heapq.heapreplace(H,6)
print(H)
[1, 3, 5, 78, 21, 45]
[3, 6, 5, 78, 21, 45]