• Qidirish usullari samaradorligi va optimallashtirish.
  • Binar qidiruv (teng ikkiga bo’lish usuli)




    Download 1 Mb.
    bet4/8
    Sana07.10.2024
    Hajmi1 Mb.
    #273965
    1   2   3   4   5   6   7   8
    Bog'liq
    Ma\'lumotlar tuzilmasi va algaritim-1

    Binar qidiruv (teng ikkiga bo’lish usuli).


    Faraz qilaylik, o’sish tartibida tartiblangan sonlar massivi berilgan bo’lsin. Ushbu usulni asosiy g’oyasi shundan iboratki, tasodifiy qandaydir AM element olinadi va u X qidiruv argumenti bilan taqqoslanadi. AgarAM=X bo’lsa, u holda qidiruv yakunlanadi; agar AM M >X bo’lsa.
    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 elementni, ya’ni massiv o’rtasini tanlasak yechim mukammal bo’ladi.

    Qidirish usullari samaradorligi va optimallashtirish.


    Ketma-ket qidiruvni samaradorligi. Ixtiyoriy qidiruvning samaradorligi jadvaldagi ma’lumotlarning kalitlari bilan solishtirish soni – S bilan baxolanishi mumkin. Agar taqqoslashlar (solishtirish) soni qancha kichik bo’lsa, qidiruv algoritmi samaradorligi shuncha yaxshi bo’ladi.
    Massivda ketma-ket qidiruvning samaradorligi quyidagicha bo’ladi:
    C = 1 n, C = (n + 1)/2.
    Umuman olganda ro’yxatda xam samaradorlik yuqoridagi kabi bo’ladi. Garchi massivda xam bog’langan ro’yxatda xam qidiruv samaradorligi bir xil bo’lsada, ma’lumotlarni massiv va ro’yxat ko’rinishda tasvirlashning o’ziga xos kamchilik va afzalliklari mavjud. Qidiruvning maqsadi - quyidagi jarayonlarni bajarilishidan iborat:

    1. Topilgan yozuvni o’qish.

    2. Qidirilayotgan yozuv topilmasa, uni jadvalga qo’yish.

    3. Topilgan yozuvni o’chirish.

    Birinchi jarayon (qidiruvning o’zi) massiv uchun ham ro’yxat uchun ham bir xil bo’ladi. Ikkinchi va uchinchi jarayonda esa qidiruv ro’yxatli tuzilmada samaraliqroq bo’ladi (sababi massivda elementlarn siljitish lozim).
    Agar k massivda elementlarni siljitishlar soni bo’lsa, u xolda k = (n + 1)/2
    bo’ladi.

    Download 1 Mb.
    1   2   3   4   5   6   7   8




    Download 1 Mb.

    Bosh sahifa
    Aloqalar

        Bosh sahifa



    Binar qidiruv (teng ikkiga bo’lish usuli)

    Download 1 Mb.