Oqituvchi: Akbarova Marg’uba




Download 1.25 Mb.
bet1/5
Sana13.12.2023
Hajmi1.25 Mb.
#117905
  1   2   3   4   5
Bog'liq
malumotlar tuzilmasi
320, 1.«Elastiklik» termini 1885 yilda ilk bor kim tomonidan talab va, Google Docsda hujjatlarni birgalikda tahrirlash, Google Formsda onlayn savolnomalar hamda testlar yaratish, Konvertatsiya fayllarni bir formatdan boshqa formatga o’tkazish, 2-Mustaqil ta'lim, 23-may 3-topshiriq, Reja Pedagogik texnologiyalarning ilmiy asoslari, 4 вариант, TDA, Документ Microsoft Word, Ahror1, Kompyuter grafikasi # rgb rang modeli qaerda ishlatiladi, Doc150

Muhammad Al-Xorazmiy nomidagi Toshken Axborot Texnologiyalari Universiteti Televizion Texnologiyalar Fakultetining 512-22 guruh talabasi Durdibayev Shamurat Malumotlar tuzilmasi va algoritmlar fanidan mustaqil ishi




Oqituvchi: Akbarova Marg’uba

MAVZU:Binar qidiruv usullari
Ishdan maqsad: binar qidiruv usullari orqali 1 dan n gacha bo’lgan sonlar ichidan ixtiyoriy elenementni topish dasturini tuzing va samaradorligini tahlil qilish.

Mazkur ko’rinishdagi qidiruv agar ma’lumotlar tartibsiz yoki ular tuzilishi noaniq bo’lganda qo’llaniladi. Bunda ma’lumotlar butun jadval bo’yichida operativ xotirada kichik adresdan boshlab, to katta adresgacha ketma-ket qarab chiqiladi. Massivda qidiruv (search o’zgaruvchi topilgan ele-ment tartib raqamini saqlaydi). Ketma ket qidiruv algoritmi C++ tilida quyidagicha bo’ladi:


int qidiruv(int key){
for (int i=0;i<="" p="">
if (k[i]==key) { search = i;return search;}
search = -1;
return search;
}}
Massivda ketma-ket qidiruv algoritmi samaradorligini bajarilgan taqqoslashlar
soni M bilan aniqlash mumkin. Mmin = 1, Mmax = n. Agar ma’lumotlar 
massiv yacheykasida bir xil ehtimollik bilan taqsimlangan bo’lsa, (n + 1)/2 bo’ladi.
Agar kerakli element jadvalda yo’q bo’lib, uni jadvalga qo’shish lozim bo’lsa, u holda yuqorida keltirilgan algoritmdagi oxirgi ikkita operator quyidagicha almashtiriladi.
n=n+1;
k[n-1]:=key;
r[n-1]:=rec;
search:=n-1;
return search;
Agar ma’lumotlar jadvali bir bog’lamli ro’yhat ko’rinishida berilgan bo’lsa (2.1rasm), u holda ketma-ket qidiruv ro’yhatda amalga oshiriladi. 
Chiziqli bir bog’lamli ro’yhatdan key kalitga mos elementni ketma-ket 
qidiruv usuli yordamida izlab topish dasturi.
Node *q=NULL;
Node *p=lst;
while (p !=NULL){
if (p->k == key){
search = p;
return search;
}
q = p;
p = p->nxt;
}
Node *s=new Node;;
s->k=key;
s->r=rec;
s->nxt= NULL;
if (q == NULL){ s->nxt=lst; lst = s; }

else q->nxt = s;


search= s;
return search;
Ro’yhatli tuzilmaning afzalligi shundan iboratki, ro’yhatga elementni qo’shish yoki o’chirish tez amalga oshadi, bunda qo’shish yoki o’chirish element soniga bog’liq bo’lmaydi, massivda e elementni qo’shish yoki o’chirish o’rta hisobda barcha elementlarning yarmini siljitishni talab qiladi. Ro’yhatda qidiruvning samaradorligi taxminan massivniki bilan bir xil bo’ladi. 
Faraz qilaylik, o’sish tartibida tartiblangan sonlar massivi berilgan bo’lsin. Ushbu usulning asosiy g’oyasi shundan iboratki, tasodifiy qandaydir  va u X qidiruv argumenti bilan taqqoslanadi. Agar AM=X bo’lsa, u holda qidiruv yakunlanadi; agar AM<="" p="">bo’lgan barcha elementlar kelgusi qidiruvdan chiqarib yuboriladi. Xuddi shuningdek, agar AM >X bo’lsa, u holda indekslari M dan katta bo’lgan barcha elementlar kelgusi qidiruvdan chiqarib yuboriladi. M ixtiyoriy tanlanganda ham taklif qilinayotgan algoritm korrekt ishlaydi. Shu sababali M ni shunday tanlash lozimki, tadqiq qilinayotgan algoritm samaraliroq natija bersin, ya’ni uni shunday tanlaylikki, iloji boricha kelgusi jarayonlarda ishtirok etuvchi elementlar soni kam bo’lsin. Agar biz o’rtacha , ya’ni massiv o’rtasini tanlasak yechim mukammal bo’ladi.


Download 1.25 Mb.
  1   2   3   4   5




Download 1.25 Mb.