Daraxt – bu shunday chiziqsiz bog‘langan ma’lumotlar tuzilmasiki, u quyidagi belgilari bilan tavsiflanadi: daraxtda shunday bitta element borki, unga boshqa elementlardan murojaat yo‘q. Bu element daraxt ildizi deyiladi



Yüklə 108,47 Kb.
səhifə7/9
tarix18.12.2023
ölçüsü108,47 Kb.
#184135
1   2   3   4   5   6   7   8   9
binar daraxt

4.10. Binar daraxt balandligi
Binar daraxtning balandligi deb daraxt bosqichlari soniga aytiladi. Binar daraxt balandligini aniqlash uchun uning har bir tuguni chap va o‘ng qismdaraxtlari balandliklari solishtiriladi va maksimal qiymat balandlik deb olinadi. Misol uchun quyidagi 8.9-rasmdagi daraxtning balandligi 2 ga teng.

4.9-rasm. Binar daraxt balandligi
Daraxt balandligini aniqlash dastur kodini keltiramiz.
int height(node *tree){
int h1,h2;
if (tree==NULL) return (-1);
else {
h1 = height(tree->left);
h2 = height(tree->right);
if (h1>h2) return (1 + h1);
else return (1 + h2);
}
}

Ishni bajarishga namuna
Topshiriq variantlariga o‘xshash bitta misolning algoritmi va to‘liq dasturini ko‘rib chiqaylik.
Misol: berilgan binar daraxtdan ko‘rsatilgan key kalitga mos tugunni o‘chirish dasturini tuzing.
Algoritm
Asosiy dastur tanasi - int main()

  1. i=0; n – daraxtga kiritiladigan elementlar sonini aniqlash. Daraxt ildizi ko‘rsatkichi tree=NULL. Next yangi elementni joylashtiradigan shoxga o‘tishda ishlatiladi va last next dan 1 qadam orqada yuradi.

  2. Agar i bo‘lsa, daraxtga kiritiladigan navbatdagi elementga qiymat kiritish va uni yangi p element info maydoniga yozish, left va right maydonlarga NULL yozish. Aks holda 8-qadamga o‘tish.

  3. Agar tree=NULL bo‘lsa, p ni daraxt ildizi qilish, ya’ni tree=p va next=last=p.

  4. Agar p->info next->info dan kichik bo‘lsa, chap shoxga o‘tish kerak, ya’ni last=next va next=next->left, aks holda o‘ng shoxga o‘tamiz, ya’ni last=next va next=next->right.

  5. Agar next=NULL bo‘lsa, 6-qadamga o‘tish, aks holda 4-qadamga o‘tish.

  6. Agar p->infoinfo bo‘lsa, last->left=p, aks holda last->right=p.


  7. Yüklə 108,47 Kb.

    Dostları ilə paylaş:
1   2   3   4   5   6   7   8   9




Verilənlər bazası müəlliflik hüququ ilə müdafiə olunur ©azkurs.org 2024
rəhbərliyinə müraciət

gir | qeydiyyatdan keç
    Ana səhifə


yükləyin