Tiplarni dinamik tarzda
Download 1.83 Mb.
|
Tiplarni dinamik tarzda
- Bu sahifa navigatsiya:
- Inspektorlar
- Fasilitatorlar (koordinatorlar)
Standart algoritmlar. Yangi dasturlashni boshlanuvchilar odatda saralash, qidirish yoki qator elementlarini sanash kabi nisbatan oddiy vazifalarni bajarish uchun maxsus takrorlanishga asoslangan usullarni yozish uchun juda ko‘p vaqt sarflashadi. Bu usullar ularda xato qilish qanchalik osonligi jihatidan ham, umumiy ishonchlilik va mavjudlik nuqtai nazaridan ham muammoli bo‘lishi mumkin, chunki bu usullar tushunish qiyin bo‘lishi mumkin.
Qidiruv, sanash va saralash dasturlashda juda keng tarqalgan amallar bo‘lganligi sababli, C++ standart kutubxonasi dastlab bu vazifalarni bir necha qator kodda bajaradigan katta funksiyalar to‘plamini o‘z ichiga olgan. Bundan tashqari, bu xususiyatlar oldindan sinovdan o‘tgan, samarali va turli xil konteynerlarni qo‘llab-quvvatlaydi. Bu xususiyatlarni ham paralel qo‘llab – quvvatlash tezroq uni bajarish uchun bir xil masala uchun bir necha MP (markaziy protsessor) oqimlarini ajratish qobiliyati ega. Algoritm kutubxonasi tomonidan taqdim etiladigan funksiyalar odatda uch toifadan biriga kiradi: Inspektorlar (nazoratchilar) - konteynerdagi maʻlumotlarni (masalan, qidirish yoki elementlarni soni hisoblash amallari) ko‘rish uchun ishlatiladi. Mutatorlar - konteynerdagi maʻlumotlarni o‘zgartirish uchun ishlatiladi (masalan, saralash yoki elementlarni qayta tartibga solish amallari). Fasilitatorlar (koordinatorlar) - elementlarining qiymatlari asosida natija hosil qilish uchun ishlatiladi (masalan, qiymatlarni ko‘paytiruvchi obʻyektlar yoki elementlarning qaysi tartib juftliklarida tartiblanishi kerakligini aniqlovchi obʻyektlar). Bu algoritmlar algoritm kutubxonasida ( find() algoritmi – berilgan qiymat bo‘yicha elementlarni qidirish algoritmi. Berilgan qiymatni birinchi topgunicha ishlaydi. Argument sifatida 3 ta paramertni oladi. ketma-ketlikda boshlang‘ich element uchun iterator; ketma-ketlikda oxirgi element uchun iterator; qidirishning qiymati. Qidirish natijada qidirilayotgan qiymatli elementga (agar u topilsa) yoki iteratorning oxiriga (agar bunday element topilmasa) ishora qiluvchi iterator qaytadi. 5.1-dastur. Find () funksiyasidan foydalanish.
find_if() algoritmi - shart orqali elementni izlash. Juda ko‘p hollarda konteynerda mavjud elementlar orasida maʻlum bir qiymat saqlaydigan element bormi degan masala duch kelamiz. Masalan, konteynerda satrli elementlar berilgan bo‘lsa, biror bir satr qismi bormikan degan masala bo‘lsin. Mana shunday masalalarni yechishda find_if() algoritmi eng mos va qulay hisoblanadi. Bu algoritm find() algoritmi bilan analog sifatida ishlaydi ammo, qidirish uchun qiymat o‘rniga funksiya ko‘rsatgichlariga moslangan element qiymatida o‘xshashlik bor bo‘lgan obʻyekt chaqiriladi. find_if() funksiyasi buning uchun har bir elementni chaqiradi va to shunday elementni topilmaguncha yoki konteynerda elementlar tugaguncha. Maʻlum bir berilgan satr bo‘yicha, berilgan konteynerda shu satrni o‘zida qism satr qilib saqlovchi elemeni bor ki yo‘qligini aniqlovchi dasturni tuzish kerak bo‘lsin. 5.2-dastur. find_if() funksiyasidan foydalanish.
Agar odatdagi standart tarzdagidek muammoni hal qilshganimizda, kamida ikki takrorlanish kerak edi (birinchi takrorlanish elementlarni saralash uchun va ikkinchisi satr qismini solishtirish uchun). Standart C++ kutubxonasining vazifalari bir nechta fragment satrlarida ham shunday qilish imkonini beradi. count() va count_if() algoritmlari – konteynerdan berilgan elementlarini sanash vazifasini bajaradi. Berilgan mezon (shart) bo‘yicha barcha elementlarni tekshirib, sanaydi. Berilgan konteynerda nechta element berilgan satr qismi borligini sanash dasturini keltiramiz. 5.3-dastur. count() va count_if() algoritmlaridan foydalanish.
sort() algoritmi – foydalanuvchining saralash funksiyasini qurish uchun ishlatiladi. Oldinlari sort() funksiyasi bilan massivlarni saralagan bo‘lshingiz mumkin, ammo sort() funksiya bu bilan chegaralanib qolmaydi. Bu funksiya yordamchi bir funksiya oladi va bu argument asosida foydalanuvchi o‘zining saralash uslubini amalga oshirishi mumkin. Funksiya esa taqqoslash uchun paramert ikkita parametr oladi. Agar birinchi element ikkinchisidan oldin bo‘lishi kerak bo‘lsa, ikkinchi paramert true qiymat qaytarishi kerak. Odatda sort() funksiyasi o‘sish tartibida saralaydi. Berilgan massivni kamayish tartibida saralash dasturini tuzaylik. 5.4-dastur. sort() funksiyasidan foydalanish.
Dasturdan ko‘rinadiki, o‘zimiz saralash algoritmini boshidan yozishimiz shart emas ekan, buning uchun bir qator fragment yetarli bo‘ldi. Ammo C++ tili, juda ko‘p saralashning kamayish tartibda foydalanganligi uchun greater{} tipli funksiyasi bo‘lishi mumkin ( greater{} funksiyasi figurali qavsga muxtoj, shuning uchun uni funksiya deb atalmaydi, maʻlumot tipi deb yuritiladi va undan foydalanish uchun nusxasini yaratishimiz kerak. Figurali qavslar anonim obʻyektlarni yaratish uchun xizmat qiladi. for_each() algortmi – konteynerning barcha elementlari o‘tish. Bu for_each() funksiyasi kiruvchi maʻlumot sifatida to‘plamni qabul qiladi va foydalanuvchining funksiyasini joriy to‘plamdagi har bir element uchun qabul qiladi. Buning qulaylik tomoni shundaki, agar bir amalni to‘plamning barcha elementlari bo‘yicha bajarish kerak bo‘lsa, for_each() funksiyasi as qotadi. Berilgan massivning barcha elementlarini chiqarish uchun for_each() funksiyasidan foydalanishni dasturini keltiraylik. 5.5-dastur. for_each() funksiyasidan foydalanish.
Yosh dasturchilar uchun bu takrorlanish jarayonini oddiy for operatoriga aniq parametrlarni qo‘yib ishlatish maquldir. for_each() funksiyasining yutuqlari shandan iboratki, takrorlanish tanasidan qayta foydalanish va paralellashtirish, katta proektlarda katta maʻlumotlar, turli tiplari har xil maʻlumotlar tuzilmasi bilan ishlgandan eng yaxshi isntrument bo‘lib xizmat qiladi. Download 1.83 Mb. Do'stlaringiz bilan baham: |
ma'muriyatiga murojaat qiling