Contoh pokok carian carian binari
Pokok carian binari (BST) adalah pokok binari di mana subtree kiri hanya mengandungi nod dengan nilai kurang daripada nilai nod, subtree yang betul mengandungi hanya nod dengan nilai lebih besar daripada nilai nod, dan kedua -dua subtrees juga mesti menjadi BST; 1. Pelaksanaan C termasuk struktur treenode dengan nilai, kiri, dan penunjuk kanan; 2. Kelas BST menyediakan operasi sisipan, carian, dan inorder menggunakan kaedah penolong rekursif; 3. Sisipan mengekalkan harta BST dengan membandingkan nilai dan mengelakkan pendua; 4. Carian beroperasi di O (log N) masa purata dengan menavigasi kiri atau kanan berdasarkan perbandingan; 5. Traversal In-Order mencetak nilai dalam urutan yang disusun dengan melawat kiri, akar, kemudian kanan; 6. Pertimbangan utama untuk pengeluaran termasuk menambah pemusnah untuk pembersihan memori, mengimbangi pokok menggunakan AVL atau logik hitam-hitam, dan melaksanakan kaedah berulang untuk mencegah limpahan timbunan, menjadikan contoh ini pemahaman asas BSTS dalam c.
Berikut adalah contoh praktikal C Search Tree (BST) dengan operasi asas: masukkan, cari, dan traversal dalam pesanan.

✅ Apakah pokok carian binari?
BST adalah pokok binari di mana:
- Subtree kiri nod mengandungi hanya nod dengan nilai kurang daripada nilai nod.
- Subtree yang betul mengandungi hanya nod dengan nilai yang lebih besar daripada nilai nod.
- Kedua -dua subtrees kiri dan kanan juga mesti menjadi pokok carian binari.
? C Contoh pelaksanaan
#include <iostream> menggunakan ruang nama STD; // Tentukan struktur nod pokok struct treenode { nilai int; Treenode* kiri; Treenode* betul; // Pembina Treenode (int val): nilai (val), kiri (nullptr), kanan (nullptr) {} }; // kelas pokok carian binari kelas BST { awam: Treenode* root; // Pembina Bst (): root (nullptr) {} // fungsi memasukkan awam void sisipkan (nilai int) { root = InserTrecursive (root, nilai); } // fungsi carian awam carian bool (nilai int) { kembali SearchRecursive (root, nilai); } // traversal in-order (mencetak nilai dalam urutan yang disusun) void inorder () { inorderRecursive (root); cout << endl; } Swasta: // penolong: masukkan nod secara rekursif Treenode* insertrecursive (treenode* node, int value) { // jika pokok kosong, buat nod baru jika (node == nullptr) { mengembalikan treenode baru (nilai); } // Jika tidak, berulang pokok jika (nilai <node-> nilai) { node-> kiri = instrecursive (node-> kiri, nilai); } else if (value> node-> value) { node-> right = instrecursive (node-> right, value); } // Abaikan pendua (nilai == nod-> nilai) Node kembali; } // pembantu: cari secara rekursif bool searchRecursive (treenode* node, int value) { jika (node == nullptr) { kembali palsu; // tidak dijumpai } jika (nod-> nilai == nilai) { kembali benar; // dijumpai } jika (nilai <node-> nilai) { kembali SearchRecursive (node-> kiri, nilai); } else { kembali SearchRecursive (Node-> Right, Value); } } // penolong: traversal dalam pesanan (kiri -> root -> kanan) void inorderRecursive (treenode* node) { jika (nod! = nullptr) { inorderRecursive (node-> kiri); cout << node-> value << ""; inorderRecursive (node-> right); } } }; // Contoh penggunaan int main () { Pokok BST; // Masukkan nilai Tree.insert (50); Tree.insert (30); Tree.insert (70); Tree.insert (20); Tree.insert (40); Tree.insert (60); Tree.insert (80); // cetak traversal in-order (harus disusun) cout << "In-order traversal:"; pokok.Inorder (); // output: 20 30 40 50 60 70 80 // Cari nilai cout << "Cari 40:" << (Tree.Search (40)? "Ditemui": "tidak dijumpai") << endl; cout << "Cari 25:" << (Tree.Search (25)? "Ditemui": "tidak dijumpai") << endl; kembali 0; }
? Output:
Traversal In-Order: 20 30 40 50 60 70 80 Cari 40: dijumpai Cari 25: Tidak dijumpai
✅ Mata Utama:
- Sisipan mengekalkan harta BST dengan membandingkan nilai.
- Carian adalah cekap (O (log n) secara purata) dengan pergi ke kiri/kanan.
- Traversal dalam pesanan memberikan output yang disusun-salah satu manfaat utama BST.
- Versi ini mengabaikan nilai pendua . Anda boleh mengubahnya untuk membolehkan pendua (contohnya, dengan menggunakan
atau menyimpan kiraan).
⚠️ Nota:
Ini adalah pelaksanaan asas. Untuk kegunaan pengeluaran, pertimbangkan:

- Pembersihan memori (tambah pemusnah untuk memadam nod).
- Mengimbangi (gunakan AVL atau pokok merah hitam untuk mengelakkan pokok miring).
- Versi berulang untuk mengelakkan limpahan timbunan di pokok -pokok dalam.
Pada asasnya, contoh ini memberi anda asas yang kukuh untuk memahami bagaimana BST berfungsi dalam c.
Atas ialah kandungan terperinci Contoh pokok carian carian binari. 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)

Direktori apa yang ringkas (membuktikan) yang mencipta ringkas (membuktikan)? Modal teroka mana yang menyokong ringkas (membuktikan)? Betapa ringkasnya (membuktikan) berfungsi SP1ZKVM dan penguasaan rangkaian Opsuccon Teknologi Pengesahan rantaian rantaian membuktikan token token token token peruntukan token utiliti yang berpotensi pemegang token membuktikan ramalan harga token membuktikan aktiviti perdagangan pra-pasaran pra-pasaran ramalan masyarakat membuktikan harga token mengapa memilih yang ringkas? Succ

Direktori Apa yang ringkas (membuktikan) Modal teroka yang menyokong ringkas (membuktikan)? Betapa ringkasnya (membuktikan) Prinsip Kerja SP1ZKVM dan Rangkaian Prover Teknologi Opsuccon Teknologi Pengesahan Cross-Chain Membuktikan Token Ekonomi Token Butiran 2025, 2026, 2027-2030 Ramalan Ramalan Ramalan (membuktikan)

Jika ia meleleh apabila memadam elemen, anda mesti mengelakkan menggunakan Iterator yang gagal. ① Cara yang betul adalah menggunakannya = vec.erase (IT), dan gunakan iterator yang sah yang dikembalikan dengan memadam untuk terus melintasi; ② Idiom yang disyorkan untuk penghapusan batch: vec.erase (std :: rove_if (vec.begin (), vec.end (), syarat), vec.end ()), yang selamat dan cekap; ③ Anda boleh menggunakan iterator terbalik untuk memadam dari belakang ke depan, logiknya jelas, tetapi anda perlu memberi perhatian kepada arah keadaan. Kesimpulan: Sentiasa mengemas kini iterator dengan nilai pulangan memadam, melarang operasi pada Iterator yang gagal, jika tidak, tingkah laku yang tidak ditentukan akan dihasilkan.

Theautokeywordinc deducesthetypeofavariableFromitsinitializer, MakingCodeCleanerAndmoremaintainable.1.itreduceRosities, terutamanyaWithcomplextypesikeiterators.2.itenhancesmaintabilitybyautomaticallyAdAdAdAdAttottoTypeChanges.3.Isisnessaryaryaryypechanges

Tagdispatching menggunakan tag jenis untuk memilih kelebihan fungsi optimum semasa tempoh penyusunan untuk mencapai polimorfisme yang cekap. 1. Gunakan std :: iterator_traits untuk mendapatkan tag kategori iterator; 2. Tentukan pelbagai fungsi kelebihan DO_Advance, dan proses random_access_iterator_tag, bidrectional_iterator_tag dan input_iterator_tag masing -masing; 3. Fungsi utama My_Advance memanggil versi yang sepadan berdasarkan jenis tag yang diperolehi untuk memastikan tidak ada overhead runtime semasa keputusan masa kompilasi; 4. Teknologi ini diterima pakai oleh perpustakaan standard seperti STD :: Advance, dan menyokong penyesuaian lanjutan.

Apabila membuka perisian atau permainan, segera tiba -tiba muncul bahawa "aplikasi tidak boleh bermula secara normal (0xc0000906)" muncul, dan banyak pengguna akan dikelirukan dan tidak tahu di mana hendak bermula. Malah, kebanyakan kesilapan ini disebabkan oleh rasuah fail sistem atau perpustakaan runtime yang hilang. Jangan tergesa -gesa untuk memasang semula sistem. Artikel ini memberikan anda beberapa penyelesaian yang mudah dan berkesan untuk membantu anda memulihkan program dengan cepat. 1. Apakah ralat 0xc0000906? Kod Ralat 0xC0000906 adalah pengecualian permulaan yang biasa dalam sistem Windows, yang biasanya bermaksud bahawa program tidak dapat memuatkan komponen sistem yang diperlukan atau persekitaran yang berjalan ketika berjalan. Masalah ini sering berlaku apabila menjalankan perisian atau permainan besar. Sebab utama mungkin termasuk: Perpustakaan Runtime yang diperlukan tidak dipasang atau rosak. Pakej pemasangan perisian tidak berkesudahan

Gunakan kaedah Seekg dan Tellg std :: ifstream untuk mendapatkan saiz fail di seluruh platform. Dengan membuka fail binari dan meletakkannya hingga akhir, gunakan Tellg () untuk mengembalikan bilangan bait; 2. Adalah disyorkan untuk menggunakan std :: filesystem :: file_size untuk c 17 dan ke atas. Kod ini ringkas dan kesilapan dikendalikan melalui pengecualian. Piawaian C 17 mesti diaktifkan; 3. Pada sistem POSIX, fungsi stat () boleh digunakan untuk mendapatkan saiz fail dengan cekap, yang sesuai untuk senario sensitif prestasi. Kaedah yang sesuai harus dipilih berdasarkan pengkompil dan platform, dan sistem fail std :: harus digunakan terlebih dahulu (jika ada), jika tidak, gunakan IFStream untuk memastikan keserasian, atau gunakan ST pada sistem Unix

Contoh C Linked ini melaksanakan Operasi Sisip, Traversal dan Padam. 1. Gunakan InsertBeginning untuk memasukkan nod di kepala; 2. Gunakan sisipan untuk memasukkan nod dalam ekor; 3. Gunakan DeletEnode untuk memadam nod dengan nilai dan mengembalikan hasil Boolean; 4. Gunakan kaedah paparan untuk melintasi dan mencetak senarai yang dipautkan; 5. Percuma semua memori nod dalam pemusnah untuk mengelakkan kebocoran; Output program akhir mengesahkan ketepatan operasi ini, menunjukkan sepenuhnya kaedah pengurusan asas struktur data dinamik.
