Struktur Data dan Algoritma - Antrian
Antrian adalah struktur data abstrak, agak mirip dengan Tumpukan. Tidak seperti tumpukan, antrean terbuka di kedua ujungnya. Salah satu ujungnya selalu digunakan untuk memasukkan data (enqueue) dan ujung lainnya digunakan untuk menghapus data (dequeue). Antrian mengikuti metodologi First-In-First-Out, yaitu item data yang disimpan terlebih dahulu akan diakses terlebih dahulu.
Contoh antrian dunia nyata dapat berupa jalan satu arah satu jalur, di mana kendaraan masuk lebih dulu, keluar lebih dulu. Contoh dunia nyata lainnya dapat dilihat sebagai antrian di loket tiket dan halte bus.
Representasi Antrian
Seperti yang sekarang kita pahami bahwa dalam antrian, kita mengakses kedua ujungnya karena alasan yang berbeda. Diagram berikut yang diberikan di bawah ini mencoba menjelaskan representasi antrian sebagai struktur data -
Seperti di stack, antrian juga dapat diimplementasikan menggunakan Array, Linked-list, Pointers dan Structures. Demi kesederhanaan, kami akan mengimplementasikan antrian menggunakan array satu dimensi.
Operasi Dasar
Operasi antrian mungkin melibatkan menginisialisasi atau menentukan antrian, menggunakannya, dan kemudian menghapusnya sepenuhnya dari memori. Di sini kita akan mencoba memahami operasi dasar yang terkait dengan antrian -
enqueue() - tambahkan (simpan) item ke antrian.
dequeue() - hapus (akses) item dari antrian.
Beberapa fungsi lagi diperlukan untuk membuat operasi antrian yang disebutkan di atas efisien. Ini adalah -
peek() - Mendapat elemen di depan antrian tanpa menghapusnya.
isfull() - Memeriksa apakah antrian sudah penuh.
isempty() - Memeriksa apakah antrian kosong.
Dalam antrian, kami selalu melakukan dequeue (atau mengakses) data, yang ditunjukkan oleh front pointer dan saat memasukkan (atau menyimpan) data dalam antrian yang kami bantu rear penunjuk.
Pertama-tama, mari pelajari tentang fungsi pendukung antrean -
mengintip()
Fungsi ini membantu untuk melihat data di frontdari antrian. Algoritme fungsi peek () adalah sebagai berikut -
Algorithm
begin procedure peek
return queue[front]
end procedure
Implementasi fungsi peek () dalam bahasa pemrograman C -
Example
int peek() {
return queue[front];
}
penuh()
Karena kami menggunakan array dimensi tunggal untuk mengimplementasikan antrian, kami hanya memeriksa penunjuk belakang untuk mencapai MAXSIZE untuk menentukan bahwa antrian sudah penuh. Jika kita mempertahankan antrian dalam daftar tertaut melingkar, algoritme akan berbeda. Algoritma dari fungsi isfull () -
Algorithm
begin procedure isfull
if rear equals to MAXSIZE
return true
else
return false
endif
end procedure
Implementasi fungsi isfull () dalam bahasa pemrograman C -
Example
bool isfull() {
if(rear == MAXSIZE - 1)
return true;
else
return false;
}
kosong()
Algoritma fungsi isempty () -
Algorithm
begin procedure isempty
if front is less than MIN OR front is greater than rear
return true
else
return false
endif
end procedure
Jika nilai front kurang dari MIN atau 0, ini memberitahu bahwa antrian belum diinisialisasi, oleh karena itu kosong.
Berikut kode pemrograman C -
Example
bool isempty() {
if(front < 0 || front > rear)
return true;
else
return false;
}
Operasi Enqueue
Antrian mempertahankan dua penunjuk data, front dan rear. Oleh karena itu, operasinya relatif sulit untuk diterapkan dibandingkan dengan stack.
Langkah-langkah berikut harus dilakukan untuk memasukkan (memasukkan) data ke dalam antrian -
Step 1 - Periksa apakah antriannya penuh.
Step 2 - Jika antrian penuh, menghasilkan error overflow dan keluar.
Step 3 - Jika antrian tidak penuh, tambahkan rear pointer untuk menunjukkan ruang kosong berikutnya.
Step 4 - Tambahkan elemen data ke lokasi antrian, di mana bagian belakang mengarah.
Step 5 - sukses kembali.
Terkadang, kami juga memeriksa untuk melihat apakah antrian diinisialisasi atau tidak, untuk menangani situasi yang tidak terduga.
Algoritma untuk operasi antrian
procedure enqueue(data)
if queue is full
return overflow
endif
rear ← rear + 1
queue[rear] ← data
return true
end procedure
Implementasi enqueue () dalam bahasa pemrograman C -
Example
int enqueue(int data)
if(isfull())
return 0;
rear = rear + 1;
queue[rear] = data;
return 1;
end procedure
Operasi Dequeue
Mengakses data dari antrian adalah proses dari dua tugas - mengakses data di mana frontmenunjuk dan menghapus data setelah akses. Langkah-langkah berikut diambil untuk melakukandequeue operasi -
Step 1 - Periksa apakah antrian kosong.
Step 2 - Jika antrian kosong, menghasilkan kesalahan aliran bawah dan keluar.
Step 3 - Jika antrian tidak kosong, akses data dimana front menunjuk.
Step 4 - Penambahan front pointer untuk menunjuk ke elemen data berikutnya yang tersedia.
Step 5 - Kembalikan sukses.
Algoritma untuk operasi dequeue
procedure dequeue
if queue is empty
return underflow
end if
data = queue[front]
front ← front + 1
return true
end procedure
Implementasi dequeue () dalam bahasa pemrograman C -
Example
int dequeue() {
if(isempty())
return 0;
int data = queue[front];
front = front + 1;
return data;
}
Untuk program Queue lengkap dalam bahasa pemrograman C, silahkan klik disini .