4.5-rasm. 3 ta elemetdan iborat binar daraxt
Binar daraxtlari ko‘rigini uchta tamoyili mavjud. Ularni berilgan daraxt misolida ko‘rib chiqaylik:
1) Yuqoridan pastga ko‘rik (daraxt ildizini qism daraxtlarga nisbatan oldinroq ko‘rikdan o‘tkaziladi): A, B, C ;
2) Chapdan o‘ngga: B, A, C ;
3) Quyidan yuqoriga (ildiz qism daraxtlardan keyin ko‘riladi): B, C, A .
Daraxt ko‘rigi ko‘pincha ikkinchi usul bilan, ya’ni tugunlarga kirish ularning kalit qiymatlarini o‘sish tartibida amalga oshiriladi.
4.5. Daraxt ko‘rigining rekursiv funksiyalari int pretrave(node *tree){
Mazkur funksiyaning vazifasi shundan iboratki, u berilgan kalit bo‘yicha daraxt tuguni qidiruvini amalga oshiradi. Qidiruv operatsiyasining davomiyligi daraxt tuzilishiga bog‘liq bo‘ladi. Haqiqatdan, agar elementlar daraxtga kalit qiymatlari o‘sish (kamayish) tartibida kelib tushgan bo‘lsa, u holda daraxt 8.7-rasmdagidek bir tomonga yo‘nalgan ro‘yhat hosil qiladi (chiqish darajasi bir bo‘ladi, ya’ni yagona shoxga ega), masalan:
4.7-rasm. Bir tomonlama yo‘naltirilgan binar daraxt tuzilishi
Bu holda daraxtda qidiruv vaqti, bir tomonlama yo‘naltirilgan ro‘yhatdagi kabi bo‘lib, o‘rtacha qarab chiqishlar soni N/2 bo‘ladi. Agar daraxt muvozanatlangan bo‘lsa, u holda qidiruv eng samarali natija beradi. Bu holda qidiruv dan ko‘p bo‘lmagan elementlarni ko‘rib chiqadi.
Qidiruv funksiyasini ko‘rib chiqamiz. searchfuksiyasi daraxtdan key kalitga mos elementning adresini aniqlaydi.
int search(node *tree, int key){ node *next; next=tree;