Belajar Algoritma & Struktur Data Python #25 |Stack - Python Implementation
Achmad Yoga Bactiar Teguh Suseno
20 Maret 2023
Stack adalah struktur data yang mengikuti prinsip LIFO (Last-In-First-Out), yang berarti elemen terakhir yang dimasukkan ke dalam stack adalah elemen pertama yang dikeluarkan dari stack. Stack digunakan dalam berbagai aspek pemrograman, termasuk pengelolaan tumpukan data, eksekusi fungsi, dan manajemen riwayat. Dalam artikel ini, kita akan mengenal dan mengimplementasikan stack dalam program Python.
Mengenal Operasi-operasi Dasar pada Stack:
Sebelum kita mengimplementasikan stack dalam Python, mari kita kenali beberapa operasi dasar yang biasa dilakukan pada stack:
Push: Operasi untuk menambahkan elemen ke atas stack. Elemen ini menjadi elemen teratas stack.
Pop: Operasi untuk mengeluarkan elemen teratas stack dan mengembalikan nilainya. Elemen ini dihapus dari stack.
Top (Peek): Operasi untuk melihat elemen teratas stack tanpa menghapusnya.
Implementasi Stack dalam Python:
Dalam Python, stack dapat diimplementasikan dengan menggunakan daftar (list). Mari kita lihat contoh implementasinya:
class Stack:
def __init__(self):
self.items = [] # Inisialisasi stack sebagai daftar kosong
def is_empty(self):
return len(self.items) == 0
def push(self, item):
self.items.append(item) # Menambahkan elemen ke atas stack
def pop(self):
if not self.is_empty():
return self.items.pop() # Mengeluarkan elemen teratas stack
else:
return None
def top(self):
if not self.is_empty():
return self.items[-1] # Melihat elemen teratas stack
def size(self):
return len(self.items)
Dalam implementasi di atas, kita mendefinisikan kelas Stack
yang memiliki metode-metode untuk operasi-operasi dasar pada stack. Metode push()
digunakan untuk menambahkan elemen ke atas stack, metode pop()
digunakan untuk mengeluarkan elemen teratas stack, metode top()
digunakan untuk melihat elemen teratas stack tanpa menghapusnya, dan metode is_empty()
serta size()
digunakan untuk memeriksa apakah stack kosong atau menghitung jumlah elemen dalam stack.
Contoh Penggunaan Stack:
Berikut adalah contoh penggunaan stack dalam program Python:
# Membuat objek stack
stack = Stack()
# Menambahkan elemen ke atas stack
stack.push(1)
stack.push(2)
stack.push(3)
# Melihat elemen teratas stack
print("Elemen teratas stack:", stack.top())
# Mengeluarkan elemen dari stack
popped_item = stack.pop()
print("Elemen yang dikeluarkan:", popped_item)
# Melihat jumlah elemen dalam stack
print("Jumlah elemen dalam stack:", stack.size())
Hasil dari contoh penggunaan di atas akan menampilkan elemen teratas stack, elemen yang dikeluarkan, dan jumlah elemen dalam stack.
Stack adalah struktur data penting dalam pemrograman yang mengikuti prinsip LIFO. Dalam Python, stack dapat diimplementasikan dengan menggunakan daftar (list) dan beberapa metode untuk operasi-operasi dasar seperti push, pop, top, dan lainnya. Stack berguna dalam berbagai aplikasi pemrograman, seperti pengelolaan tumpukan data, eksekusi fungsi, validasi tumpukan karakter, dan sebagainya.
Artikel Lainnya Dengan Kategori Terkait :
1. Belajar Algoritma & Struktur Data Python #01 |Apa itu Algoritma
2. Belajar Algoritma & Struktur Data Python #02 |Representasi dan Perencanaan Algoritma - Pseudocode
3. Belajar Algoritma & Struktur Data Python #03 |contoh Pseudocode
4. Belajar Algoritma & Struktur Data Python #04 |Apa itu Struktur Data
5. Belajar Algoritma & Struktur Data Python #05 |Searching Algorithm Sequential vs Binary
6. Belajar Algoritma & Struktur Data Python #07 |Binary Search - Definition
7. Belajar Algoritma & Struktur Data Python #08 |Sequential Search - Definition
8. Belajar Algoritma & Struktur Data Python #09 |Sequential Search - Python Implementation
9. Belajar Algoritma & Struktur Data Python #10 |Sorting Algorithm
10. Belajar Algoritma & Struktur Data Python #11 |Bubble Sort - Concept
11. Belajar Algoritma & Struktur Data Python #12 |Bubble Sort - Python Implementation
12. Belajar Algoritma & Struktur Data Python #13 |Selection Sort - Concept
13. Belajar Algoritma & Struktur Data Python #14 |Selection Sort - Python Implementation
14. Belajar Algoritma & Struktur Data Python #15 |Insertion Sort - Concept
15. Belajar Algoritma & Struktur Data Python #16 |Insertion Sort - Python Implementation
16. Belajar Algoritma & Struktur Data Python #17 |Merge Sort - Concept - 1
17. Belajar Algoritma & Struktur Data Python #18 |Merge Sort - Concept 2
18. Belajar Algoritma & Struktur Data Python #19 |Merge Sort - Python Implementation
19. Belajar Algoritma & Struktur Data Python #20 |Quick Sort - Concept 1
20. Belajar Algoritma & Struktur Data Python #21 |Quick Sort - Concept 2
21. Belajar Algoritma & Struktur Data Python #22 |Quick Sort - Python Implementation
22. Belajar Algoritma & Struktur Data Python #23 |Selection Sort - Concept
23. Belajar Algoritma & Struktur Data Python #24 |Apa itu Stack
24. Belajar Algoritma & Struktur Data Python #25 |Stack - Python Implementation
25. Belajar Algoritma & Struktur Data Python #26 |Apa itu Queue
26. Belajar Algoritma & Struktur Data Python #27 |Queue - Python Implementation
27. Belajar Algoritma & Struktur Data Python #28 |Apa itu Hash Table
28. Belajar Algoritma & Struktur Data Python #29 |Konsep Hashing
29. Belajar Algoritma & Struktur Data Python #30 |Mendeklarasikan Hash Table sebagai classcar
30. Belajar Algoritma & Struktur Data Python #31 |Mengimplementasikan Hash Table
31. Belajar Python Lanjutan #01 |Function - Basic Structure
32. Belajar Python Lanjutan #02 |Function - Call a Function
33. Belajar Python Lanjutan #03 |Function - Arguments and Parameters
34. Belajar Python Lanjutan #04 |Function - Arbitrary Arguments
35. Belajar Python Lanjutan #05 |Default Parameters
36. Belajar Python Lanjutan #06 |Default Parameters in Multiple Parameters
37. Belajar Python Lanjutan #07 |Set - Difference Of Set
38. Belajar Python Lanjutan #08 |Function - Keyword Parameter
39. Belajar Python Lanjutan #09 |Function - Return Statement
40. Belajar Python Lanjutan #10 |Recursive Function
41. Belajar Python Lanjutan #11 |Lambda - Expression and Syntax
42. Belajar Python Lanjutan #12 |Lambda - Filter
43. Belajar Python Lanjutan #13 |Lambda - Map
44. Belajar Python Lanjutan #14 |Lambda - Reduce
45. Belajar Python Lanjutan #15 |Nested Function Concept
46. Belajar Python Lanjutan #16 |Default Parameters in Multiple Parameters
47. Belajar Python Lanjutan #17 |Non-local Variable - Local Variable vs Global Variable
48. Belajar Python Lanjutan #18 |Closure - Concept
49. Belajar Python Lanjutan #19 |Class - Definition and Concept of Object
50. Belajar Python Lanjutan #20 |Class - Instances vs Class
51. Belajar Python Lanjutan #21 |Class - Declaring and Self Parameters
52. Belajar Python Lanjutan #22 |Class - Constructor init Method
53. Belajar Python Lanjutan #23 |Instance Variables
54. Belajar Python Lanjutan #24 |Class Variables
55. Belajar Python Lanjutan #25 |Class - Inheritence
56. Belajar Python Lanjutan #26 |Default Parameters in Multiple Parameters
57. Belajar Python Lanjutan #27 |Class - Polymorphism
58. Belajar Python Lanjutan #28 |Class - Encapsulation
59. Belajar Python Lanjutan #29 |Class - Abstraction
60. Belajar Python Lanjutan #30 |Apa itu Concurrency dan Parallelism
61. Belajar Python Lanjutan #31 |threading
62. Belajar Python Lanjutan #32 |library threading
63. Belajar Python Lanjutan #33 |Multiprocessing
64. Belajar Python Lanjutan #34 |Implementasi library multiprocessing
65. Belajar Python Lanjutan #35 |Kemiripan multiprocessing dengan threading
Mahardika Oktadiansyah - 17 April 2025
Belajar CSS Lanjutan #122 | Responsive Web Design - Images
Mahardika Oktadiansyah - 17 April 2025
Belajar CSS Lanjutan #121 | Responsive Web Design - Media Queries
Mahardika Oktadiansyah - 17 April 2025
Belajar CSS Lanjutan #120 | Responsive Web Design - Building a Grid View