Zbekiston respublikasi aloqa, axborotlashtirish va telekommunikatsiya




Download 490,46 Kb.
bet25/47
Sana15.11.2023
Hajmi490,46 Kb.
#99136
1   ...   21   22   23   24   25   26   27   28   ...   47
left

info

right

4.3-rasm. Binar daraxt elementining tuzilishi


Ushbu toifada element hosil qilish uchun oldin bu toifani yaratib olishimiz kerak. Uni turli usullar bilan amalga oshirish mumkin. Masalan, node nomli yangi toifa yaratamiz:


class node{
public:
int info; node *left; node *right;
};
Endi yuqoridagi belgilashlarda keltirilgan ko‟rsatkichlarni shu toifada yaratib olamiz.
node *tree=NULL; node *next=NULL;
int n,key; cout<<"n=";cin>>n;
Nechta element (n) kiritilishini aniqlab oldik va endi har bir element qiymatini kiritib, binar daraxt tuzishni boshlaymiz.
for(int i=0;i
node *p=new node; node *last=new node; cin>>key;
p->info=key;
p->left=NULL; p->right=NULL;
if(i==0){ tree=p; next=tree;sontinue;} next=tree;
while(1){ last=next;
if(p->infoinfo) next=next->left; else next=next->right; if(next==NULL) break;
}
if(p->infoinfo) last->left=p; else last->right=p;
}
Bu yerda p hali aytganimizdek, kiritilgan kalitga mos hosil qilingan yangi element ko‟rsatkichi, next yangi element joylashishi kerak bo‟lgan joyga olib boradigan shox adresi ko‟rsatkichi, ya‟ni u har doim p dan bitta qadam oldinda yuradi, last esa ko‟rilayotgan element kimning avlodi ekanligini bildiradi, ya‟ni u har doim p dan bir qadam orqada yuradi (4.4-rasm).

4.4-rasm. Binar daraxt elementlarini belgilash


Shunday qilib binar daraxtini ham yaratib oldik. Endigi masala uni ekranda tasvirlash kerak, ya‟ni u ko‟rikdan o‟tkaziladi yoki vizuallashtirsa ham bo‟ladi.

      1. Download 490,46 Kb.
1   ...   21   22   23   24   25   26   27   28   ...   47




Download 490,46 Kb.

Bosh sahifa
Aloqalar

    Bosh sahifa



Zbekiston respublikasi aloqa, axborotlashtirish va telekommunikatsiya

Download 490,46 Kb.