- Klasifikasi Antrian Berujung Ganda
- Operasi Deque Dasar
- Ilustrasi Deque
- Implementasi Deque
- Aplikasi
- Kesimpulan
Tutorial Mendalam tentang Deque atau Antrian Berujung Ganda di C++. Tutorial menjelaskan Apa itu Deque, Operasi Dasar, C++ & Implementasi dan Aplikasi Java:
Antrian berujung ganda atau hanya disebut "Deque" adalah versi umum dari Antrian.
Perbedaan antara Queue dan Deque adalah bahwa Queue tidak mengikuti pendekatan FIFO (First In, First Out). Fitur kedua dari Deque adalah kita dapat memasukkan dan menghapus elemen dari ujung depan atau belakang.
Klasifikasi Antrian Berujung Ganda
Deque dapat diklasifikasikan sebagai berikut:
Deque yang dibatasi input: Dalam input-terbatas, penghapusan dapat dilakukan dari kedua ujungnya, tetapi penyisipan hanya dapat dilakukan di ujung belakang antrean.
Deque yang dibatasi keluarannya: Dalam antrian yang dibatasi output, penyisipan dapat dilakukan dari kedua ujungnya tetapi penghapusan hanya dilakukan pada satu ujung, yaitu ujung depan antrian.
Kita juga dapat mengimplementasikan tumpukan dan antrian menggunakan deque.
Operasi Deque Dasar
Berikut ini adalah operasi dasar yang dapat dilakukan pada deque.
- masukkan bagian depan: Sisipkan atau tambahkan item di bagian depan deque.
- insertLast: Sisipkan atau tambahkan item di bagian belakang deque.
- hapusDepan: Menghapus atau memindahkan item dari depan antrean.
- hapus terakhir: Menghapus atau menghapus item dari bagian belakang antrean.
- getFront: Mengambil item depan dalam deque.
- getLast: Mengambil item terakhir dalam antrean.
- isEmpty: Memeriksa apakah deque kosong.
- isFull: Memeriksa apakah deque sudah penuh.
Ilustrasi Deque
Deque kosong direpresentasikan sebagai berikut:
Berikutnya, kita menyisipkan elemen 1 di bagian depan.
Sekarang, kita sisipkan elemen 3 di bagian belakang.
Selanjutnya, kita tambahkan elemen 5 ke depan dan ketika ditambah, bagian depan menunjuk ke 4.
Kemudian, kita sisipkan elemen 7 di bagian belakang dan 9 di bagian depan. Deque akan terlihat seperti gambar di bawah ini.
Berikutnya, mari kita hapus elemen dari depan.
Dengan demikian, kita melihat bahwa apabila elemen disisipkan di bagian depan, posisi depan dikurangi sementara posisi depan ditambah apabila elemen dilepas. Untuk bagian belakang, posisinya ditambah untuk penyisipan dan dikurangi untuk pelepasan .
Implementasi Deque
Implementasi C++ Deque
Kita dapat mengimplementasikan deque di C++ menggunakan array dan juga senarai berantai. Selain itu, Standard Template Library (STL) memiliki kelas "deque" yang mengimplementasikan semua fungsi untuk struktur data ini.
Implementasi array dari deque telah diberikan di bawah ini. Karena ini adalah antrean berujung ganda, kami telah menggunakan array melingkar untuk implementasi.
#includeusing namespace std; #define MAX_size 10 // Ukuran maksimum array atau Dequeue // Deque class class Deque { int array[MAX_size]; int front; int rear; int size; public : Deque(int size) { front = -1; rear = 0; this->size = size; } // Operasi pada Deque: void insertfront(int key); void insertrear(int key); void deletefront(); void deleterear(); int getFront(); int getRear(); // Cek apakah Deque adalahpenuh bool isFull() return ((depan == 0 && belakang == ukuran-1) // Periksa apakah Deque kosong bool isEmpty(){ return (depan == -1); } }; // Menyisipkan elemen pada bagian depan Deque void Deque::insertfront(int key) { if (isFull()) { cout <<"Melimpah!!\n" <<endl; return; } // Jika antrean pada awalnya kosong, set depan = belakang = 0; awal deque if (depan == -1) { depan = 0; belakang = 0; } else if(front == 0) // front adalah posisi pertama dari antrian front = size - 1 ; else // pengurangan 1 posisi front front = front-1; array[front] = key; // memasukkan elemen saat ini ke dalam Deque } // memasukkan elemen di ujung belakang deque void Deque ::insertrear(int key) { if (isFull()) { cout <<"Overflow!!!" <<endl; return; } // Jika antrian pada awalnya kosong, set front = rear = 0; awal dari deque if(depan == -1) { depan = 0; belakang = 0; } else if (belakang == ukuran-1) // belakang berada di posisi terakhir antrian belakang = 0; else // kenaikan belakang sebanyak 1 posisi belakang = belakang+1; array[belakang] = key; // masukkan elemen saat ini ke dalam Deque } // Menghapus elemen pada bagian depan Deque void Deque ::deletefront() { if (isEmpty()) { cout <<"Antrian Underflow!!\n" <<endl; return; } // Deque hanya memiliki satu elemen jika(depan == belakang) { depan = -1; belakang = -1; } else // kembali ke posisi awal if (depan == ukuran -1) depan = 0; else // hapus nilai depan saat ini dari Deque; kenaikan depan sebesar 1 depan = depan + 1; } // hapus elemen pada bagian belakang Deque void Deque::deleterear() { if (isEmpty()) { cout <<"Underflow!!!" <<endl; return; } // Deque hanya mempunyai satu elemen if (depan == belakang) { depan = -1;belakang = -1; } else if (belakang == 0) belakang = ukuran-1; else belakang = belakang-1; } // mengambil elemen depan dari Deque int Deque::getFront() { if (isEmpty()) { cout <<"Underflow!!!" <<endl; return -1; } return array[depan]; } // mengambil elemen belakang dari Deque int Deque::getRear() { if (isEmpty())//main program int main() { Deque dq(5); cout <<"Insert element 1 at rear end \n"; dq.insertrear(1); cout <<"insert element 3 at rear end \n"; dq.insertrear(3); cout <<"rear element of deque " <<" " <<dq.getRear() <<endl; dq.deleterear(); cout <<"After deleterear, rear = " <<dq.getRear() <<endl; cout <<"inserting element 5 atfront end \n"; dq.insertfront(5); cout <<"elemen depan deque " <<" " <<dq.getFront() <<endl; dq.deletefront(); cout <<"Setelah deletefront, front = " <<dq.getFront() <<endl; return 0; }
Keluaran:
Sisipkan elemen 1 di ujung belakang
sisipkan elemen 3 di ujung belakang
elemen belakang deque 3
Setelah dihapus, belakang =
memasukkan elemen 5 di ujung depan
elemen depan deque 5
Setelah menghapus bagian depan, bagian depan =
Implementasi Java Deque
Antarmuka deque di Java, "java.util.Deque" berasal dari antarmuka "java.util.Queue". Deque dapat digunakan sebagai antrian (First In, First Out) atau tumpukan (Last In, First Out). Implementasi ini bekerja lebih cepat daripada linked list.
Di bawah ini adalah hierarki untuk antarmuka Deque di Java.
Kita perlu mengingat beberapa hal tentang antarmuka Deque di Java:
- Implementasi ini tidak aman untuk thread karena tidak ada sinkronisasi eksternal.
- Deque tidak mendukung konkurensi oleh beberapa thread.
- Deque yang diimplementasikan menggunakan array tidak mengizinkan penggunaan elemen NULL.
- Array diizinkan untuk berkembang sesuai kebutuhan, dengan kapasitas bebas batasan dan dukungan array yang dapat diubah ukurannya menjadi dua fitur yang paling penting.
Berikut ini adalah berbagai metode yang didukung oleh antarmuka Deque:
Tidak. | Metode | Deskripsi |
---|---|---|
1 | menambahkan (elemen) | Menambahkan elemen ke ekor. |
2 | addPertama (elemen) | Menambahkan elemen ke bagian kepala/depan. |
3 | addLast (elemen) | Menambahkan elemen ke bagian ekor/belakang. |
4 | penawaran (elemen) | Menambahkan elemen ke ekor; mengembalikan nilai boolean untuk mengindikasikan apakah penyisipan berhasil. |
5 | menawarkanPertama(elemen) | Menambahkan elemen ke kepala; mengembalikan nilai boolean untuk menunjukkan apakah penyisipan berhasil. |
6 | menawarkanTerakhir(elemen) | Menambahkan elemen ke ekor; mengembalikan nilai boolean untuk mengindikasikan apakah penyisipan berhasil. |
7 | iterator() | Mengembalikan iterator untuk deque. |
8 | descendingIterator() | Mengembalikan iterator yang memiliki urutan terbalik untuk deque ini. |
9 | push(elemen) | Menambahkan elemen ke kepala deque. |
10 | pop(elemen) | Menghapus elemen dari kepala deque dan mengembalikannya. |
11 | hapusPertama() | Menghapus elemen di bagian kepala deque. |
12 | hapusTerakhir() | Menghapus elemen di bagian ekor deque. |
13 | poll() | Mengambil dan menghapus elemen pertama dari deque (diwakili oleh kepala deque); mengembalikan NULL jika deque kosong. |
14 | pollFirst() | Mengambil dan menghapus elemen pertama dari deque ini; mengembalikan null jika deque ini kosong. |
15 | pollLast() | Mengambil dan menghapus elemen terakhir dari deque ini; mengembalikan null jika deque ini kosong. |
16 | mengintip() | Mengambil kepala (elemen pertama dari deque) dari antrean yang diwakili oleh deque ini; mengembalikan null jika deque ini kosong. Catatan: Operasi ini tidak menghapus elemen. |
17 | mengintipPertama() | Mengambil elemen pertama dari deque ini; mengembalikan null jika deque ini kosong. Catatan: Operasi ini tidak menghapus elemen. |
18 | mengintipTerakhir() | Mengambil elemen terakhir dari deque ini, atau mengembalikan null jika deque ini kosong. Catatan: Operasi ini tidak menghapus elemen. |
Implementasi Java berikut ini mendemonstrasikan berbagai operasi yang telah dibahas di atas.
import java.util.*; class Main { public static void main(String[] args) { Dequedeque = new LinkedList (); // Kita bisa menambahkan elemen ke antrian dengan berbagai cara deque.add(1); // menambahkan ke ekor deque.addFirst(3); deque.addLast(5); deque.push(7); //menambahkan ke kepala deque.offer(9); deque.offerFirst(11); deque.offerLast(13); System.out.println("Deque: " + deque + "\n"); // Mengiterasi elemen antrian. System.out.println("Standard Iterator"); Iterator iterator = deque.iterator(); while(iterator.hasNext()) System.out.print(" " + iterator.next()); // Membalikkan urutan iterator Iterator reverse = deque.descendingIterator(); System.out.println("\nBalikkan Iterator"); while (reverse.hasNext()) System.out.print(" " + reverse.next()); // Mengintip mengembalikan head, tanpa menghapusnya dari deque System.out.println("\n\nMengintip" + deque.intip()); System.out.println("Setelah mengintip: " + deque);// Pop mengembalikan kepala, dan menghapusnya dari // deque System.out.println("\nPop " + deque.pop()); System.out.println("Setelah pop: " + deque); // Kita bisa mengecek apakah elemen tertentu ada // di dalam deque System.out.println("\nBerisi elemen 3?: " + deque.contains(3)); // Kita bisa menghapus elemen pertama/terakhir. deque.removeFirst(); deque.removeLast(); System.out.println("Deque setelah menghapus "+ "elemen pertama dan terakhir: " + deque); } }
Keluaran:
Deque: [11, 7, 3, 1, 5, 9, 13]
Iterator Standar
11 7 3 1 5 9 13
Iterator Terbalik
13 9 5 1 3 7 1
Mengintip 11
Setelah mengintip: [11, 7, 3, 1, 5, 9, 13]
Pop 11
Setelah pop: [7, 3, 1, 5, 9, 13]
Berisi elemen 3?: benar
Deque setelah menghapus elemen pertama dan terakhir: [3, 1, 5, 9]
Pada program di atas, kita telah menggunakan antarmuka Deque pada Java dan mendefinisikan sebuah deque yang terdiri dari elemen-elemen bilangan bulat, kemudian kita melakukan berbagai operasi pada deque ini dan menampilkan hasil dari operasi-operasi tersebut.
Aplikasi
Deque dapat digunakan dalam beberapa aplikasi berikut ini.
#1) Algoritma Penjadwalan: Algoritma penjadwalan, "Algoritma penjadwalan A-steal" mengimplementasikan penjadwalan tugas untuk berbagai prosesor dalam sistem multiprosesor. Implementasi ini menggunakan deque dan prosesor mendapatkan elemen pertama dari deque untuk dieksekusi.
#2) Batalkan Daftar Kegiatan: Dalam aplikasi perangkat lunak, kita memiliki banyak tindakan, salah satunya adalah "undo." Ketika kita telah melakukan tindakan undo berkali-kali, semua tindakan ini disimpan dalam sebuah daftar. Daftar ini dipertahankan sebagai deque sehingga kita dapat dengan mudah menambah/menghapus entri dari ujung mana pun.
#3) Hapus Entri Setelah Beberapa Waktu: Aplikasi menyegarkan entri dalam daftar mereka seperti aplikasi yang mencantumkan entri saham, dll. Aplikasi ini menghapus entri setelah beberapa waktu dan juga memasukkan entri baru. Hal ini dilakukan dengan menggunakan deque.
Kesimpulan
Deque adalah antrean berujung ganda yang memungkinkan kita untuk menambah/menghapus elemen dari kedua ujungnya, yaitu depan dan belakang, dari antrean. Deque dapat diimplementasikan dengan menggunakan array atau linked list. Namun, kami juga memiliki kelas Standard Template Library (STL) yang mengimplementasikan berbagai operasi Deque.
Di Java, kita memiliki antarmuka Deque yang diwarisi dari antarmuka antrian untuk mengimplementasikan Deque. Terlepas dari operasi standar dasar Deque, antarmuka ini mendukung berbagai operasi lain yang dapat dilakukan pada Deque.
Deque umumnya digunakan untuk aplikasi yang membutuhkan penambahan/penghapusan elemen dari kedua ujungnya. Deque juga banyak digunakan dalam penjadwalan prosesor dalam sistem multi-prosesor.
Lihat Seri Pelatihan C++ Lengkap