Algoritmlash



Download 12,86 Mb.
bet4/121
Sana02.09.2021
Hajmi12,86 Mb.
#162549
1   2   3   4   5   6   7   8   9   ...   121
Bog'liq
Algoritmlash va dasturlash asoslari (A.Azamatov)

1.3-rasm.

y o l g ‘on r o s t yYoOLl gG''OoNn

maBu kabi mulohazalarl chap bo'sh sharti va chapga ko'rsat- ya si, lyana boshqa juft iklar uchun ham to‘g‘ri. Ro‘yxatni kun ash uchun Robot biladigan oxirgi shartni keltiramiz:

bo‘yalgan

7



m Bu shart Robot turgan kvadratni bo'yalgan. yoki bo‘yal- aganligini tekshirish imkonini beradi. Agar kvadrat bo'yalgan

bo‘lsa, shart ROST, aks holda YOLG'ON bo'ladi.

uni Ko'ribt turibsiz,uRobotning iko'rsatmalari juda sodda. Lekin

ma o‘rab urgan m hit xilma-x l imkoniyatlarga boy. Robotning

va ydonida turli labirintlar, yoMaklar, har xil shakldagi xonalar

qo‘boshqa figuralar yordamida ijuda ko‘p qiziqarli masalalar

yish mumkin. Robotning m krohayoti — algoritmik tafak-

kurni rivojlantirish uchun a‘lo darajadagi mashq maydonidir. Ijrochilarni boshqalari bilan tanishtirishdan awal ularni nimalar farqlab turishini izohlab o'tmoqchimiz. Ijrochini quyidagilar farqlab turadi:

• ijrochi muhiti; ■ ijrochining ko'rsatmalar sistemasi;

• sodda amallar; • INKOR.

Ijrochi muhiti — ijrochi «yashaydigan» yoki algoritmni baja- radigan muhiti. Ijrochi Robot misolida bu katakli maydon, bo'yalgan kataklar va devorlar. Ularning joylashishi va Robot- ning turgan joyi muhitning aniq holatini beradi.

ko‘Har bir ijrochi qat‘iy belgilangan ro‘yxatdagi — ijrochining

ko rsatmalar sistemasidagi ko‘rsatmalarninbajara oladi. Har bir

ko‘rsatmanuchun jqo'llashushartii (muhit ing qanday holatida

n 'rsatma ling ba arish m imkinl gi) vaako‘rsatmani bajarilish

atijasi be gilangan bo‘lish kerak. Mas lan, yuqoriga ko‘rsat-

masi Robotning yuqorisida devor yo‘q bo'lsagina bajarish mum- kin. Bu ko‘rsatmaning bajarilish natijasi — Robot yuqoriga bitta katak siljiydi.

Ko‘rsatma chaqirilgandan keyin Ijrochi sodda amal bajaradi.

Robot misolida — yuqoriga bitta katak siljish.

bo INKOR — bu holat bo‘lib, ko‘rsatma muhitning mumkin

'lmagan holatida chaqirilganda yuz beradi. Robot misolida

qarasak, agar u devor ichidan o'tmoqchi bo‘lsa, «sochilib» ketadi va bu Robot uchun INKOR holatiga olib keladi.

Yodingizda bo‘lsin: Ijrochi algoritm maqsadi haqida hech narsa bilmaydi, u berilgan ko‘rsatmalarni so‘zsiz bajaradi, xolos.

Algoritmning xossalari

Algoritmning tavsifida «biror maqsadga erishishga qaratilgan» jumlasi qo‘llanilgan. Bu maqsadni yuqorida keltirilgan mi- sollarda ko'rishimiz mumkin: ko'chadan o‘tish, g'ishtlar sonini

8




hisoblash, yig‘indini hisoblash. Bular algoritmning natijaviylik (cheklilik) xossasi bilan bog‘liq. Bu xossaning mazmuni shundan iboratki, har qanday algoritm ijrochi chekli qadamdan so‘ng oxir-oqibat ma’lum bir yechimga olib kelishi kerak. Shuni ta'kidlash joizki, algoritm awaldan ko‘zlangan maqsadga eri- shishga olib kelmasligi ham mumkin. Bunga ba'zan algoritm- ning noto‘g‘ri tuzilgani yoki boshqa xatolik sabab bo'lishi mum- kin. Ikkinchi tomondan, qo'yilgan masala ijobiy yechimga ega bo‘lmasligi ham mumkin. Lekin salbiy natija ham natija deb qabul qilinadi.

1.4-misol



x2+x+ \ = 0 kvadrat tenglama yechilsin.

Bu tenglamaga quyida keltirilgan «ax2+bx+c= 0 (uN50) ko‘ri- nishidagi kvadrat tenglamani yechish» algoritmini qoMlab, teng- lama yechimga ega emasligini aniqlaymiz. Bu ham natija ekanligi sizga ma'Ium.

1) diskriminant: D = b2—4ac hisoblansin;

oli 2)nagar5D < 0abo‘lsa,n; tenglama yechimga ega emas deb

nsi va -bandg o'tilsi

3) agar D = 0 boMsa, yagona y echim -----2aga teng deb olinsin va 5-bandga o'tilsin;



-b-J~D -b + jD

4) birinchi yechim 2a ga, ikkinchi yechim 2a

ga teng deb olinsin;

5) tugallansin.

1.1-mashq

E'tibor qilgan bo Isangiz, diskriminantning noldan kichikligi, nolga tengligi tekshirildi, ammo noldan kattaligi tekshirilmadi. Sababini o'ylab ko'ring!

bir Demak, algoritm doimo chekli qadamdan iborat bo'lishi lva (u or natija l berishi ) kerak ekan. Bu algoritmni diskretli ik y zluklilik, a ohidalikhxossasiga olib keladi. Algoritmda masalani kechish jarayoni alodida olingandsodda ko‘rsatmalar ketma- etligini qadam-baqa am bajarish an iborat boMishi kerak. Bu

xossa misollardan yaqqol ko‘rinib turibdi. «Angliyada avto-

mobilni yoMning chap qismida haydang» qoidasi talabnoma

9




boMgani bilan uzluksizlik xarakteriga ega va shuning uchun ham algoritm hisobiga qo'shilmaydi.

sol E'tiboringizni yana bir narsaga qaratamiz. oKeltirilgan mi-

yo larda quyidagi jumlalar bor: «Ko‘chadan ‘tish»t (ariqdan

jo ki dengizdan emas), «Eni 6 metr var bo‘yi 10 me r bo‘lgan

g yni* (kilometr emas), «eni 12 santimet tva bo‘yi 25 santimetrli

‘ishtlar» (eni 5 santimetrva bo‘yi 100 san imetrli g'ishtlar emas),

«x2+ x + l= 0 kvadrat tenglama» (x2—1 = 0 kvadrat tenglama emas). Bu jumlalar va qavs ichida yozilganlarni taqqoslasangiz, olinadigan natija shu jumlalardagi «qiymat»larga chambarchas bog'liq ekanligini tushunasiz. Agar bu «qiymatlar» o'zgarsa, masalan, qavs ichidagilarga, olinadigan natija umuman bosh- qacha bo'lishini ko'rish qiyin emas. Qiymat so‘zini qo‘shtirnoq ichiga olganimizga sabab, siz doimo qiymat so'zini faqat sonlar bilan bog'Iab o'rganib kelgansiz. Lekin, bilingki, biror masala uchun qiymat har xil turdagi obyektlar bo'lishi mumkin ekan. Demak, har bir algoritmning natijasi awaldan berilgan, ya’ni boshlang'ich qiymatiarga bog'liq bo'lar ekan. Boshlang'ich qiymatlar turli natijalarga olib kelishiga yana bir hayotiy misolga o'zingiz javob bera olasiz: sizga va mehmonga kelgan do‘stlarin- gizga pishiralayotgan palovga 20 gramm tuz solish o'rniga 200 gramm tuz solishsa natija bir xil boMadimi?

ula Har bir algoritm — bu amallami ‘belgilovchia qoida bo'lib,

ming zanjiri natijasida biz boshlang ich qiymatl rdan izlangan

natijaga kelamiz. Bunday amallar zanjiri algoritmik jarayon, har bir amal — algoritmning qadami deb ataladi.

Yana boshlang‘ich qiymat va natija bo'lishi mumkin bo'lgan narsalarning tahliliga qaytamiz. Ko'rdikki, har bir algoritm uchun boshlangMch qiymatlaming turli hollarini tanlash mumkin. Masalan, g'ishtlar masalasi algoritmi uchun boshlangMch qiy- matlarni tavsiflashda «santimeir» so‘zlarini «uzunlik o‘lchovlari» kabi tushunish mumkin. Bu holda hosil boMadigan natijaning miqdori o‘zgaradi, xolos. Ko‘p algoritmlar boshlangMch qiy- matlarning turli hollari uchun o‘z kuchini saqlab qoladi. Qo‘shish algoritmini ixtiyoriy natural sonlar jufti uchun qoMlash mumkin. Awal aytib oMiigan algoritmlarning aniqlangan bu xossasi (ulami boshlangMch qiymatlarning juda ko‘p sondagi hollariga qoMlash mumkinligi) ommaviylik deb ataladi. Yuqorida keltirilgan

«ax2+ftx+c = 0 (

algoritmi ixtiyoriy a, b, c haqiqiy sonlar uchun natija beradi,

10




ya'ni algoritmning ommaviylik xossasi o'rinli ekan. Algo- ritmlarning juda ko‘p xususiy hollarda ishlashi shunday o‘ta muhim va ahamiyatli xossa, shu sababli ancha vaqtgacha uni algoritmning ilmiy ta'rifiga kiritilishi shart deb hisoblandi. Bu ko'pgina qoidalarni fan sohasidan chiqarib tashlar (ularni «oz miqdordagi» ommaviyligi tufayli) va ham ilmiy tadqiqotni, ham uiarning natijasini amaliyotda qoMlashni qiyinlashtirar (balki bu ilmiy boMmagan hol bo‘lsa-chi?), bu esa jiddiy noqulaylikka sabab bo'ladi. BoshlangMch qiymatlarning faqat bitta —yagona holiga qoMlash mumkin boMgan algoritm ham katta ahamiyat kasb etadi. Ularga turli xil avtomatlardan (masalan, agar aniq bir tangaga moslangan gazeta sotadigan avtomat, yoki telefon- avtomat) foydalanish algoritmlari tegishlidir, aniq bir joydan boshlanadigan va belgilangan joyga olib boradigan yo‘nalish bo‘yicha borish algoritmi va boshqalar.

uy «Ommaviylik» atamasining mavhumligi mashhur, ba'zan

ta um l paradoksi adebs ataluvchi, iEvbulid paradoksi eorqali

ja sdiq anadi. Par dok i mazmunin i o'zimizga savol b rib va

vobini berib tezda an qlab olishim z mumkin.

Uc Bitta tosh — uyummi? Yo‘q. Ikkita tosh-chi? Yana yo‘q.

htasi-chi? Oxir-oqibat, biz yoki uyum mavjud emas degan

xulosaga, yoki shunday sondagi toshlar to'plami borki, undan bitta oshsa uyum hosil boMishiga olib keladi, deb e'tirof etishga majbur boMamiz. U yoki bu fikr ham haqiqatga ziddir va bu uyum atamasining mavhumiigining natijasi boMib hisoblanadi. Nima boMganda ham ommaviylik xossasidan oddiygina «bo‘yin tov!ash» mumkin emas. Uni ta'riflashni ozgina o‘zgartirish hamda shuning asosida yuqorida aytib o'tilgan mavhumlikni yo'qotish zarur.

Bu «Ommaviylik» atamasiga qanday mazmunukiritish ikerak?

obysavolga javob shunday. Har bir algoritm si chun b ror-bir

ularektlar (narsalar, buyumlar i va hokazo) o nfi mavjud va

deb ning barchasi boshlang'ich q ymat sifatidao linishi mumkin,

algorhisoblash nzarur. i Manfiymas butun s nlami qo‘shish

avto itmi auchuos manf ymas butun sonlarningbbarcha juftligi;

uch matd n «Tn hkent oqshomi» gazetasini sotii olish algoritmi

Algunt — yago a obyekt — tanga shundayas nf boMa oladi.

ori mning ommaviyligi — mos sinfning b rcha obyektlarini

qoMlash mumkinligidir, ya'ni, ularning qandaydir miqdorining (chekli yoki cheksiz) qo'llash mumkin emasligi emas. Mumkin

11



bo‘lgan, ya’ni joiz obyektlarning miqdori chekli yoki cheksizligi, yoki miqdori nolga teng bo'lishi —bu shu sinfning xususiyatidir. izl Agar algoritm yordamida joiz boshlang‘ich qiymat asosida

b angan natijani iolish mumkin bo‘lsa u holda algoritmni joiz

bosh(ang‘ich q ymatgaz qo‘llash mumkin a deyiladi.u Agar boshlang‘ichoqiymat joi o bo‘lsa ham natij i olish m mkin oMmasa, u h lda unga alg ritm qo‘llash mumk n emas deyiladi.

ko‘Endi joiz boshlang‘ichgqiymatlar sinfi qanday ekanligini

rib chiqamiz. Boshlan ‘ich qiymatlar ba‘zan narsa yoki

buyumlar, sonlar ekanini ko‘rdik. Bu fikr olingan natijalar uchun ham o'rinli. Bu narsalar orasidagi umumiylik nimada? Algo- ritm — bu qoidalar va demakki, ular qandaydir tillarda ifoda- langan, degan fikrni e’tiborga olsak, bu umumiylik ko'rinadi. Bir necha marta bu qoidalarning aniq bajarilishi qanchalik muhim ekanligi haqida gapirib o‘tdik.

bil Lekin bunday aniqabajarilishi boshlang‘ich iqiymatlar (ular

an birga izlangan n tijalar ham) biror-bir t lda, balki yan-

gisida, batamom tavsiflanishga imkon bersagina mumkin. Bu holda har bir boshlang‘ich qiymatga, har bir oraliq natijaga va nihoyat, izlangan natijaga qandaydir gap mos keladi. Yana, mazkur gapning «Mazmun»i bir qiymatli bo'lishi zarur. shuMatematikada ko'pincha maxsus usul qo‘llanadi. Bu usul

al ndanr iboratki, biror-bir obyekt boshqai tabiatli lobyekt bilan

q mashti iladi, bunda . yangi iobyektlarga b rlamchi ari bilan bir iymatli mos bo‘ladi Ko'r layotgan holda boshlang‘ich qiy-

matlar tilining gaplari bilan boshlang'ich qiymatlarning o‘zi orasida bir qiymatli moslik mavjud. Shu sababli, algoritmni matematik ta'riflashda boshlang‘ich qiymatlar va izlangan natijalar tilning gaplari deb hisoblanishi mumkin.

Al Bunday almashtirish amaliyot nuqtayi nazaridan mumkinmi?

m batta, mumkin. Chunki, algoritmning o‘zida boshlang‘ich qiy-

v atlar emas, ulaming nomi, jarayonni bajarish uchun esa amaliar

a hosil boMadigan natijalarning nomini bilish yetarli.

Keltirilgan usul algoritm ta'rifini tor ma'noda bo'lishiga olib keladi, deyish mumkin. Bunday fikr asoslidir. Lekin bu torayish muhim emas, chunki u algoritmlar beradigan imkoniyatlami kamaytira olmaydi.

turlBu kabibyondashishtiboshlang'ich lqiymatlar va tnatijalar

tab arini nis atan kamay radi, ammo u ar awalgidek urli fizik

iatga ega bo‘lishi mumkin, lekin biz uchun bu, ulami nazariy

12



qaraganimizda, turli tillardagi gaplar kabidir. Narsalarning turlanishini biz tillarning turlanishiga keltirdik. To‘g‘ri, tillar ham kam emas. Ularni cheksiz to‘plam (faqat mavjudlari emas, balki mavjud bo‘lishi mumkin bo'lganlari ham, ya'ni mumkinlari ham) deb hisoblash mumkin. Lekin har bir algoritm faqat ikkita til bilan bogMangan: bittasida u ta'riflangan, ikkinchisining gaplari boshlang‘ich qiymatlar hollarini uning uchun mumkin bo'lganlaridir. Birinchi tilni, odatda, algoritmik til deb, ikkin- chisini —operandlar tili deb atashadi. Operandlar deb shunday obyektlarga aytiladiki, ular ustida algoritm talab qilgan amallar bajariladi. Operandlar tilining barcha gaplari joiz deb hisob- lanadi, bu tilga tegishli bo'lmagan biror-bir belgilar birikmasi ta'rif bo‘yicha joiz emas.

Algoritmni tasvirlash usullari

algAlgoritmlarni tasvirlashning turli usullari mavjud. Quyida chioritmlarni tasvirlashning keng tarqalgan usullarini ko'rib

qamiz.



Download 12,86 Mb.

Do'stlaringiz bilan baham:
1   2   3   4   5   6   7   8   9   ...   121




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2025
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish