Bagaimana untuk memasukkan elemen ke dalam BST (DSA)?
Hari ini kita akan belajar BST dan bagaimana untuk memasukkan satu elemen (atau kita boleh mengatakan nod tunggal) ke dalam BST **. Ini mudah bagi mereka yang sudah mengetahui senarai BST dan dua kali, dan topik-topik ini penting sebelum membaca artikel ini. Jadi saya memberikan pautan kepada topik ini, anda boleh merujuknya. -
1. Untuk jadual berkaitan dua kali
2. Untuk pokok binari
Oleh itu, sebelum anda memahami cara memasukkan nod tunggal ke BST. Anda mesti tahu apa BST, BST adalah
** pokok carian binari **
Ia mempunyai beberapa sifat, seperti :-
- Nilai nod kiri lebih kecil atau dibandingkan dengan unsur akar dan kanan
- Nod akar mempunyai nilai yang lebih kecil daripada nod yang betul
- Apabila kita tiga kali ganda nod melalui aplikasi Tritree dalam pesanan, ia akan memberikan array menaik.
Nampaknya ini
Untuk memasukkan elemen ke dalam BST, kita memerlukan penunjuk ke nod akar, kerana di beberapa bahagian kita perlu membandingkan kunci kepada data akar supaya kita tahu sama ada kunci akan dimasukkan ke kiri atau kanan.
Mula -mula kita membuat nod dan memulakannya ke BST.
Ini adalah kod yang boleh anda rujuk, kod itu dilaksanakan dalam bahasa C.
#include <stdio.h> #include <stdlib.h> struct node { struct node* kiri; data int; struct node* right; }; struct node* createenode (int key) { struct node * newNode = null; newNode = malloc (sizeof (struct node)); newnode-> left = null; newNode-> data = kekunci; newnode-> right = null; kembali NewNode; } void InsertNewNode (struct node* root, int kekunci) { struct node * prev = null; sementara (root! = null) { prev = root; jika (kunci == root) { printf ("elemen tidak dapat memasukkannya di dalam BST sudah "); kembali; } lain jika (kekunci> root-> data) { root = root-> right; } lain { akar = akar-> kiri; } } struct node * newNode = createenode (kunci); jika (kunci> prev-> data) { prev-> right = newNode; } lain { prev-> left = newNode; } } void inorder (struct node* root) { jika (root == null) { pulangan akar; } inorder (akar-> kiri); printf ("%d", root-> data1`1); inorder (root-> right); } int main () { struct node* head1 = createBst (20); struct node* head2 = createBst (10); struct node* head3 = createBst (30); HEAD1-> LEFT = HEAD2; head1-> right = head3; InsertNewNode (kepala1,40); printf ("%d \ n", head1-> right-> right-> data); inorder (head1); kembali 0; } </stdlib.h></stdio.h>
Atas ialah kandungan terperinci Bagaimana untuk memasukkan elemen ke dalam BST (DSA)?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

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

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

Undress AI Tool
Gambar buka pakaian secara percuma

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











Sepuluh pertukaran mata wang digital teratas seperti Binance, OKX, Gate.io telah meningkatkan sistem mereka, urus niaga yang pelbagai dan langkah -langkah keselamatan yang ketat.

Sepuluh platform perdagangan cryptocurrency teratas di dunia termasuk Binance, OKX, Gate.io, Coinbase, Kraken, Huobi Global, Bitfinex, Bittrex, Kucoin dan Poloniex, yang semuanya menyediakan pelbagai kaedah perdagangan dan langkah -langkah keselamatan yang kuat.

Platform perdagangan mata wang digital yang boleh dipercayai: 1. Okx, 2. Binance, 3. Coinbase, 4. Kraken, 5. Huobi, 6. Kucoin, 7.

Memebox 2.0 mentakrifkan semula pengurusan aset crypto melalui seni bina yang inovatif dan kejayaan prestasi. 1) Ia menyelesaikan tiga titik kesakitan utama: silo aset, kerosakan pendapatan dan paradoks keselamatan dan kemudahan. 2) Melalui hab aset pintar, pengurusan risiko dinamik dan enjin peningkatan pulangan, kelajuan pemindahan rantaian, kadar hasil purata dan kelajuan tindak balas insiden keselamatan diperbaiki. 3) Menyediakan pengguna dengan visualisasi aset, automasi dasar dan integrasi tadbir urus, merealisasikan pembinaan semula nilai pengguna. 4) Melalui kerjasama ekologi dan inovasi pematuhan, keberkesanan keseluruhan platform telah dipertingkatkan. 5) Pada masa akan datang, kolam insurans kontrak pintar, ramalan integrasi pasaran dan peruntukan aset yang didorong AI akan dilancarkan untuk terus memimpin pembangunan industri.

Saat ini disenaraikan di antara sepuluh mata wang mata wang maya yang teratas: 1. Binance, 2 Okx, 3. Gate.io, 4. Perpustakaan duit syiling, 5. Siren, 6. Huobi Global Station, 7. Bybit, 8. Kucoin, 9.

Sepuluh pertukaran cryptocurrency teratas di dunia pada tahun 2025 termasuk Binance, OKX, Gate.io, Coinbase, Kraken, Huobi, Bitfinex, Kucoin, Bittrex dan Poloniex, yang semuanya dikenali dengan jumlah dan keselamatan perdagangan mereka yang tinggi.

Harga Bitcoin berkisar antara $ 20,000 hingga $ 30,000. 1. Harga Bitcoin telah berubah secara dramatik sejak tahun 2009, mencapai hampir $ 20,000 pada tahun 2017 dan hampir $ 60,000 pada tahun 2021. Harga dipengaruhi oleh faktor -faktor seperti permintaan pasaran, bekalan, dan persekitaran makroekonomi. 3. Dapatkan harga masa nyata melalui pertukaran, aplikasi mudah alih dan laman web. 4. Harga Bitcoin sangat tidak menentu, didorong oleh sentimen pasaran dan faktor luaran. 5. Ia mempunyai hubungan tertentu dengan pasaran kewangan tradisional dan dipengaruhi oleh pasaran saham global, kekuatan dolar AS, dan sebagainya. 6. Trend jangka panjang adalah yakin, tetapi risiko perlu dinilai dengan berhati-hati.

Mengukur prestasi thread di C boleh menggunakan alat masa, alat analisis prestasi, dan pemasa tersuai di perpustakaan standard. 1. Gunakan perpustakaan untuk mengukur masa pelaksanaan. 2. Gunakan GPROF untuk analisis prestasi. Langkah -langkah termasuk menambah pilihan -pg semasa penyusunan, menjalankan program untuk menghasilkan fail gmon.out, dan menghasilkan laporan prestasi. 3. Gunakan modul Callgrind Valgrind untuk melakukan analisis yang lebih terperinci. Langkah -langkah termasuk menjalankan program untuk menghasilkan fail callgrind.out dan melihat hasil menggunakan kcachegrind. 4. Pemasa tersuai secara fleksibel dapat mengukur masa pelaksanaan segmen kod tertentu. Kaedah ini membantu memahami sepenuhnya prestasi benang dan mengoptimumkan kod.
