Penjelasan terperinci mengenai struktur data: dari array ke pokok, dan kemudian ke jadual hash
Artikel ini membincangkan beberapa struktur data biasa secara mendalam, termasuk tatasusunan, senarai yang dipautkan, pokok carian binari (BSTs) dan jadual hash, dan menerangkan organisasi mereka dalam ingatan dan kelebihan dan kekurangannya.
Struktur maklumat dan struktur data abstrak
Struktur maklumat merujuk kepada cara maklumat dianjurkan dalam ingatan, sementara struktur data abstrak adalah pemahaman konseptual kami tentang struktur ini. Memahami struktur data abstrak membantu kami melaksanakan pelbagai struktur data dalam amalan.
Timbunan dan giliran
Beratur adalah struktur data abstrak yang mengikuti prinsip FIFO (pertama dalam, keluar pertama), sama seperti menunggu dalam barisan. Operasi utamanya termasuk enqueuing (menambahkan unsur ke ekor barisan) dan dequeuing (mengeluarkan elemen kepala barisan).
Tumpukan mengikuti prinsip LIFO (Terakhir dalam Pertama), sama seperti menyusun plat. Operasinya termasuk menolak (menambah unsur ke bahagian atas timbunan) dan muncul (mengeluarkan unsur -unsur atas timbunan).
Array
Arahan adalah struktur yang terus menyimpan data dalam ingatan. Seperti yang ditunjukkan dalam gambar di bawah, tatasusunan menduduki ruang penyimpanan berterusan dalam ingatan.
Program, fungsi, dan pembolehubah lain mungkin wujud dalam ingatan, serta data berlebihan yang telah digunakan sebelum ini. Jika anda perlu menambah elemen baru ke array, anda perlu menyusun semula memori dan menyalin keseluruhan array, yang boleh menjadi tidak cekap.
Walaupun pra-memperuntukkan memori terlalu banyak dapat mengurangkan operasi salinan, ia akan membazirkan sumber sistem. Oleh itu, adalah penting untuk memperuntukkan ingatan mengikut keperluan sebenar.
Senarai pautan
Senarai yang dipautkan adalah struktur data yang kuat yang membolehkan penggabungan nilai yang terletak di kawasan memori yang berbeza ke dalam senarai dan menyokong pengembangan atau pengurangan dinamik.
Setiap CS- Minggu 5 mengandungi dua nilai: nilai data dan penunjuk ke CS- Minggu 5 seterusnya. Nilai penunjuk CS- Minggu 5 terakhir adalah batal, menunjukkan akhir senarai yang dipautkan.
Dalam bahasa C, CS- Minggu 5 boleh ditakrifkan seperti berikut:
<code class="c">typedef struct CS- Minggu 5e { int number; struct CS- Minggu 5e *next; } CS- Minggu 5e;</code>
Contoh berikut menunjukkan proses membuat senarai yang dipautkan:
Kekurangan senarai yang dipautkan termasuk keperluan untuk penunjuk penyimpanan memori tambahan dan ketidakupayaan untuk mengakses elemen secara langsung melalui indeks.
Pokok carian binari (BST)
Pokok carian binari adalah struktur pokok yang cekap menyimpan, mencari dan mengambil data.
Kelebihan BST adalah kecekapan dinamik dan carian (O (log n)), dan kelemahannya ialah kecekapan carian jatuh ke O (n) apabila pokok itu tidak seimbang dan memerlukan penunjuk penyimpanan memori tambahan.
Jadual Hash
Jadual hash adalah serupa dengan kamus dan mengandungi pasangan nilai utama. Ia menggunakan fungsi hash untuk memetakan kekunci untuk indeks array, dengan itu mencapai masa carian purata O (1).
Konflik hash (kekunci berganda yang dipetakan ke indeks yang sama) boleh diselesaikan dengan senarai yang dipautkan atau kaedah lain. Reka bentuk fungsi hash adalah penting untuk prestasi jadual hash. Contoh fungsi hash mudah adalah seperti berikut:
<code class="c">#include <ctype.h> unsigned int hash(const char *word) { return toupper(word[0]) - 'A'; }</ctype.h></code>
Artikel ini disusun berdasarkan kod sumber CS50X 2024.
Atas ialah kandungan terperinci CS- Minggu 5. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Fungsi Readdir dalam sistem Debian adalah panggilan sistem yang digunakan untuk membaca kandungan direktori dan sering digunakan dalam pengaturcaraan C. Artikel ini akan menerangkan cara mengintegrasikan Readdir dengan alat lain untuk meningkatkan fungsinya. Kaedah 1: Menggabungkan Program Bahasa C dan Pipeline Pertama, tulis program C untuk memanggil fungsi Readdir dan output hasilnya:#termasuk#termasuk#includeintMain (intargc, char*argv []) {dir*dir; structdirent*entry; if (argc! = 2) {

Kaunter Redis adalah satu mekanisme yang menggunakan penyimpanan pasangan nilai utama REDIS untuk melaksanakan operasi pengiraan, termasuk langkah-langkah berikut: mewujudkan kekunci kaunter, meningkatkan tuduhan, mengurangkan tuduhan, menetapkan semula, dan mendapatkan tuduhan. Kelebihan kaunter Redis termasuk kelajuan cepat, konkurensi tinggi, ketahanan dan kesederhanaan dan kemudahan penggunaan. Ia boleh digunakan dalam senario seperti pengiraan akses pengguna, penjejakan metrik masa nyata, skor permainan dan kedudukan, dan pengiraan pemprosesan pesanan.

Keserasian ABI dalam C merujuk kepada sama ada kod binari yang dihasilkan oleh penyusun atau versi yang berbeza boleh serasi tanpa rekompilasi. 1. Konvensyen Calling Function, 2. Pengubahsuaian Nama, 3. Susun atur Jadual Fungsi Maya, 4. Struktur dan susun atur kelas adalah aspek utama yang terlibat.

Menggunakan Arahan Redis memerlukan langkah -langkah berikut: Buka klien Redis. Masukkan arahan (nilai kunci kata kerja). Menyediakan parameter yang diperlukan (berbeza dari arahan ke arahan). Tekan Enter untuk melaksanakan arahan. Redis mengembalikan tindak balas yang menunjukkan hasil operasi (biasanya OK atau -r).

Menggunakan REDIS untuk mengunci operasi memerlukan mendapatkan kunci melalui arahan SETNX, dan kemudian menggunakan perintah luput untuk menetapkan masa tamat tempoh. Langkah-langkah khusus adalah: (1) Gunakan arahan SETNX untuk cuba menetapkan pasangan nilai utama; (2) Gunakan perintah luput untuk menetapkan masa tamat tempoh untuk kunci; (3) Gunakan perintah DEL untuk memadam kunci apabila kunci tidak lagi diperlukan.

Gunakan pemalam JSON Viewer di Notepad untuk memformat fail JSON dengan mudah: Buka fail JSON. Pasang dan aktifkan pemalam JSON Viewer. Pergi ke "Plugins" & gt; "JSON Viewer" & gt; "Format JSON". Sesuaikan tetapan lekukan, cawangan, dan penyortiran. Memohon pemformatan untuk meningkatkan kebolehbacaan dan pemahaman, dengan itu memudahkan pemprosesan dan penyuntingan data JSON.

Hadidb: Pangkalan data Python yang ringan, tinggi, Hadidb (Hadidb) adalah pangkalan data ringan yang ditulis dalam Python, dengan tahap skalabilitas yang tinggi. Pasang HadIdb menggunakan pemasangan PIP: Pengurusan Pengguna PipInstallHadidB Buat Pengguna: CreateUser () Kaedah untuk membuat pengguna baru. Kaedah pengesahan () mengesahkan identiti pengguna. dariHadidb.OperationImportuserer_Obj = user ("admin", "admin") user_obj.

Pemecahan ingatan redis merujuk kepada kewujudan kawasan bebas kecil dalam ingatan yang diperuntukkan yang tidak dapat ditugaskan semula. Strategi mengatasi termasuk: Mulakan semula Redis: Kosongkan memori sepenuhnya, tetapi perkhidmatan mengganggu. Mengoptimumkan struktur data: Gunakan struktur yang lebih sesuai untuk Redis untuk mengurangkan bilangan peruntukan dan siaran memori. Laraskan parameter konfigurasi: Gunakan dasar untuk menghapuskan pasangan nilai kunci yang paling kurang baru-baru ini. Gunakan mekanisme kegigihan: sandarkan data secara teratur dan mulakan semula redis untuk membersihkan serpihan. Pantau penggunaan memori: Cari masalah tepat pada masanya dan ambil langkah.
