Rumah >pembangunan bahagian belakang >C++ >Perbezaan antara baris gilir tatasusunan dan baris gilir senarai terpaut
Baris gilir ialah struktur data linear yang memasukkan dan mengalih keluar elemen baris gilir dalam susunan tertentu. Kita boleh melaksanakan baris gilir dalam C++ dengan menggunakan tatasusunan dan senarai terpaut. Kedua-dua pelaksanaan baris gilir mempunyai kelebihan dan kegunaan tersendiri. Dalam tutorial ini, kami akan membezakan antara baris gilir berasaskan tatasusunan dan baris gilir berasaskan senarai terpaut.
Baris gilir ialah satu siri elemen yang menggunakan prinsip FIFO (masuk dahulu, keluar dahulu) untuk pemasukan dan pemadaman elemen. Barisan gilir dalam sains komputer adalah serupa dengan baris gilir dalam kehidupan sebenar, orang pertama yang memasuki baris gilir akan dialih keluar terlebih dahulu.
Proses mengalih keluar data giliran dipanggil deQueue. Operasi menambah data pada baris gilir dipanggil enQueue.
Barisan mempunyai dua mata -
Selepas - Elemen dari baris gilir dimasukkan dari sini.
Depan - Elemen dalam baris gilir akan dialih keluar dari sini.
Kami boleh melaksanakan baris gilir dalam dua cara -
Baris gilir berasaskan tatasusunan
Baris gilir berasaskan senarai atau baris gilir senarai terpaut
Baris gilir yang dilaksanakan menggunakan tatasusunan dipanggil baris gilir berasaskan tatasusunan. Ia menggunakan dua penunjuk: Depan dan Belakang, yang masing-masing mewakili titik pemadaman dan titik sisipan dalam Baris Gilir.
Dalam pelaksanaan ini, saiz tatasusunan dipratakrifkan sebelum memasukkan data. Ini adalah cara paling mudah untuk memasukkan dan memadam data baris gilir.
Dalam baris gilir berasaskan senarai atau baris gilir berasaskan senarai terpaut, senarai terpaut digunakan untuk pelaksanaan baris gilir. Setiap nod baris gilir terdiri daripada dua bahagian: satu bahagian digunakan untuk menyimpan data, dan bahagian lain ialah bahagian pautan atau bahagian memori.
Setiap elemen baris gilir disambungkan ke memori elemen baris gilir seterusnya. Terdapat dua penunjuk dalam baris gilir berasaskan senarai -
Penunjuk sebelumnya - Mewakili ingatan elemen baris gilir terakhir.
Penunjuk belakang - memori mewakili elemen pertama baris gilir.
S.No | ialah: Nombor Siri |
Baris gilir berasaskan tatasusunan |
Baris gilir berasaskan senarai terpaut |
|
---|---|---|---|---|
1 |
Kerumitan |
Ia mudah untuk dilaksanakan dan melaksanakan operasi. |
Bukan mudah untuk dilaksanakan. |
|
2 |
Proses carian |
Ia membantu untuk mencari dengan mudah dan cepat. |
Lambat dan sukar dicari. |
|
3 |
Saiz giliran |
Tentukan saiz baris gilir pada masa permulaan. |
Tidak perlu menentukan saiz baris gilir semasa memulakan baris gilir. |
|
4 |
Operasi pemasukan dan pemadaman |
Susah nak masukkan data pada permulaan, tapi senang nak masukkan data di hujung baris gilir. |
Ia menyediakan sisipan data mudah di kedua-dua hujung baris gilir. |
|
5 |
Akses data |
Akses data rawak. |
Ia menyediakan akses berurutan kepada elemen baris gilir. |
|
6 |
Pelarasan saiz baris gilir |
Menukar saiz giliran adalah sukar. |
Melaraskan saiz baris gilir adalah mudah. |
|
7 |
Penggunaan memori |
Ia menggunakan kurang memori. |
Ia menggunakan lebih banyak memori. |
|
8 |
Kelebihan |
|
|
|
9 |
Keburukan |
|
|
Jika baris gilir anda mempunyai saiz tetap dan tidak perlu menukar saiz baris gilir, anda boleh melaksanakan baris gilir menggunakan tatasusunan. Barisan gilir berasaskan tatasusunan juga berguna apabila carian pantas dan menggunakan kurang memori.
Pelaksanaan baris gilir berasaskan senarai terpaut sangat berguna apabila saiz baris gilir adalah dinamik dan elemen baris gilir dimasukkan dan dipadamkan beberapa kali. Walaupun ia menggunakan lebih banyak memori, ia sesuai untuk aplikasi berskala besar
Menggunakan baris gilir berasaskan tatasusunan dan baris gilir berasaskan senarai terpaut bergantung pada keperluan. Dalam aplikasi berskala besar, baris gilir berasaskan tatasusunan tidak berjaya dan baris gilir senarai terpaut digunakan sebaliknya.
Baris gilir berasaskan tatasusunan menggunakan kurang memori tetapi membazirkan banyak memori kerana selepas memasukkan elemen di bahagian belakang, beberapa memori yang tidak digunakan kekal sebelum elemen pertama.
Atas ialah kandungan terperinci Perbezaan antara baris gilir tatasusunan dan baris gilir senarai terpaut. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!