Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #include <iostream>
- #include <stdlib.h>
- using namespace std;
- // Mendefinisikan struktur node untuk merepresentasikan elemen dalam tumpukan
- struct node {
- char data;
- struct node *next;
- };
- // Memberi alias untuk struct node menjadi node
- typedef struct node node;
- // Variabel global untuk menunjukkan puncak (top) tumpukan, pilihan pengguna, item yang dimasukkan, jumlah elemen dalam tumpukan, dan status keluar dari program
- node *top = NULL;
- int choice;
- char item;
- int count = 0;
- int keluar = 0;
- // Deklarasi prototipe fungsi-fungsi
- void push(char);
- void pop();
- void printAll();
- void menu();
- // Fungsi utama
- int main() {
- // Looping menu utama
- while (!keluar) {
- menu();
- }
- return 0;
- }
- // Fungsi untuk menambahkan elemen ke tumpukan
- void push(char item) {
- // Membuat node baru
- node *temp = new node;
- temp->data = item;
- temp->next = NULL;
- // Memasukkan node baru ke dalam tumpukan
- if (top == NULL) {
- top = temp;
- } else {
- node *current = top;
- while (current->next != NULL) {
- current = current->next;
- }
- current->next = temp;
- }
- cout << "\n# PUSH : No urut/index : " << count << ", Push : " << item;
- count++;
- }
- // Fungsi untuk menghapus elemen dari tumpukan
- void pop() {
- // Mengambil elemen dari tumpukan
- if (top == NULL) {
- cout << "\n## Stack kosong";
- } else {
- node *current = top;
- node *prev = NULL;
- while (current->next != NULL) {
- prev = current;
- current = current->next;
- }
- char item = current->data;
- delete current;
- count--;
- if (prev != NULL) {
- prev->next = NULL;
- } else {
- top = NULL;
- }
- cout << "\n##POP hasil: " << item;
- cout << "\n##jumlah item dalam stack : " << count;
- }
- }
- // Fungsi untuk mencetak semua elemen dalam tumpukan
- void printAll() {
- // Mencetak semua elemen dalam tumpukan
- cout << "\n## Ukuran Tumpukan : " << count;
- node *temp = top;
- int i = count;
- while (temp != NULL) {
- cout << "\n## No Urut/index : " << i << ", Nilai :" << temp->data;
- temp = temp->next;
- i--;
- cout << "\nJonathan Arya Priguna" << endl;
- cout << "235150301111015" << endl;
- }
- }
- // Fungsi untuk menampilkan menu operasi tumpukan
- void menu() {
- // Menampilkan pilihan menu dan melakukan aksi yang sesuai
- cout << "\nMasukkan operasi yang akan dilakukan (1:push, 2:pop, 3:print) : ";
- cin >> choice;
- switch (choice) {
- case 1:
- cout << "\nMasukkan huruf yang akan dipush : ";
- cin >> item;
- push(item);
- break;
- case 2:
- pop();
- break;
- case 3:
- printAll();
- break;
- default:
- cout << "\n1:push, 2:pop, 3:print\n";
- keluar = 1;
- break;
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement