Jadual Kandungan
✅ Apakah pokok carian binari?
? C Contoh pelaksanaan
? Output:
✅ Mata Utama:
⚠️ Nota:
Rumah pembangunan bahagian belakang C++ Contoh pokok carian carian binari

Contoh pokok carian carian binari

Jul 28, 2025 am 02:26 AM
c++ pokok 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.

Contoh pokok carian carian binari

Berikut adalah contoh praktikal C Search Tree (BST) dengan operasi asas: masukkan, cari, dan traversal dalam pesanan.

Contoh pokok carian carian binari

✅ 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:

Contoh pokok carian carian binari
  • 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!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Artikel Panas

Skop pembolehubah PHP dijelaskan
1 bulan yang lalu By 百草
Mengulas kod dalam php
1 bulan yang lalu By 百草
Petua untuk menulis komen php
1 bulan yang lalu By 百草

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial PHP
1511
276
Apa itu SENDIRI (membuktikan duit syiling)? Bagaimana untuk beroperasi? Membuktikan ekonomi dan ramalan harga token Apa itu SENDIRI (membuktikan duit syiling)? Bagaimana untuk beroperasi? Membuktikan ekonomi dan ramalan harga token Aug 06, 2025 pm 06:42 PM

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

Ramalan Harga Ringkas (Buktikan Koin): 2025, 2026, 2027-2030 Ramalan Harga Ringkas (Buktikan Koin): 2025, 2026, 2027-2030 Aug 11, 2025 am 10:12 AM

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)

C Padamkan dari vektor semasa melangkah C Padamkan dari vektor semasa melangkah Aug 05, 2025 am 09:16 AM

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.

Contoh kata kunci auto c Contoh kata kunci auto c Aug 05, 2025 am 08:58 AM

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

C Contoh penghantaran tag C Contoh penghantaran tag Aug 05, 2025 am 05:30 AM

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.

Apa yang perlu saya lakukan jika aplikasi tidak boleh bermula secara normal (0xc0000906)? Lihat penyelesaian di sini Apa yang perlu saya lakukan jika aplikasi tidak boleh bermula secara normal (0xc0000906)? Lihat penyelesaian di sini Aug 13, 2025 pm 06:42 PM

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

Cara mendapatkan saiz fail dalam c Cara mendapatkan saiz fail dalam c Aug 11, 2025 pm 12:34 PM

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 senarai yang dipautkan Contoh senarai yang dipautkan Aug 05, 2025 am 06:23 AM

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.

See all articles