1- mavzu (ma'ruza) uz 1-Ma’ruza. Algoritmlash va dasturlashning asosiy tushunchalari yangi


Download 63.29 Kb.
bet3/3
Sana10.12.2020
Hajmi63.29 Kb.
#164150
1   2   3
Bog'liq
1-maruza

Ifoda tushunchasi


 С++ tilida ifoda - amallar, operandlar va punktatsiya belgilarining ketma-ketligi bo‘lib, kompilyator tomonidan berilganlar ustida ma’lum bir amallarni bajarishga ko‘rsatma deb qabul qilinadi. Har qanday ‘;’ belgi bilan tugaydigan ifodaga til ko‘rsatmasi deyiladi.

С++ tilidagi til ko‘rsatmasiga misol:

         X=X+3

         x=3*(y-2.45)+z;

        y=Summa(a,9,c);

 

Amallar bajarish ketma-ketligi


             Arifmetik ifodada bir nechta operatorlar (amallar) qatnashganda kompilyator amallar ketma-ketligini ularning ustunligiga qarab bajaradi. Avval ko’paytirish, bo’lish, bo’lishning qoldig’ini olish amallari, so’ngra qo’shish va ayirish amallari bajariladi. Masalan:

3 * 7 - 6 + 2 * 5 / 4 + 6

= (((3 * 7) – 6) + ((2 * 5) / 4 )) + 6 (* bajariladi)

= ((21 – 6) + (10 / 4)) + 6 (/ bajariladi.)

= ((21 – 6) + 2) + 6          (– bajariladi)

= (15 + 2) + 6           (birinchi + bajariladi)

= 17 + 6                 (+ bajariladi)

= 23


 

Ma’lumotlar toifasini o‘zgartirish

С++ tilida bir turni boshqa turga keltirishning oshkor va oshkormas yo‘llari mavjud.

Umuman olganda, turni boshqa turga oshkormas keltirish ifodada har xil turdagi o‘zgaruvchilar qatnashgan hollarda amal qiladi (aralash turlar arifmetikasi). Ayrim hollarda, xususan tayanch turlar bilan bogʻliq turga keltirish amallarida xatoliklar yuzaga kelishi mumkin. Masalan, hisoblash natijasidagi sonning xotiradan vaqtincha egallagan joyi uzunligi, uni o‘zlashtiradigan o‘zgaruvchi uchun ajratilgan joy uzunligidan katta bo‘lsa, qiymatga ega razryadlarni yo‘qotish holati yuz beradi.

Oshkor ravishda turga keltirishda, o‘zgaruvchi oldiga qavs ichida boshqa tur nomi yoziladi:



#include

int main(){

   int Integer_1=54;

   int Integer_2;

   float Floating=15.854;

   Integer_1=(int)Floating; // oshkor keltirish;

   Integer_2=Floating; // oshkormas keltirish;

   cout<<“Yangi Integer(Oshkor): “<

   cout<<“Yangi Integer(Oshkormas): “<

   return 0;

}

Dastur natijasi quyidagi ko‘rinishida bo‘ladi:



Yangi Integer(Oshkor): 15

Yangi Integer(Oshkormas): 15

Masala. Berilgan belgining ASCII kodi chop etilsin. Masala belgi turidagi qiymatni oshkor ravishda butun son turiga keltirib chop qilish orqali echiladi.

Dastur matni:



#include

 int main(){

    unsigned char A;

    cout<<"Belgini kiriting: ";

    cin>>A;  cout<<'\''<bajarilsa, ekranga

     'A'-belgi ASCCI kodi=65

satri chop etiladi.

 

O‘zlashtirish amali va uning mifikatsiyalari


Amallar qaytaradigan qiymatlarni o‘zlashtirish uchun qiymat berish amali (=) va uning turli modifikatsiyalari ishlatiladi: qo‘shish, qiymat berish bilan (+=); ayirish, qiymat berish bilan (-=); ko‘paytirish, qiymat berish bilan (*=); bo‘lish, qiymat berish bilan (/=); bo‘lish qoldigʻini olish, qiymat berish bilan (%=) va boshqalar. Bu holatlarning umumiy ko‘rinishi:

=;

Quyidagi dastur matnida ayrim amallarga misollar keltirilgan.



#include

int main(){

   int a=0,b=4,c=90; char z=’\t’;

   a=b; cout<a=4

   a=b+c+c+b; cout<a= 4+90+90+4 = 188

   a=b-2; cout<a=2

   a=b*3; cout<a=4*3 = 12

   a=c/(b+6); cout<a=90/(4+6) =9

   cout<9%2=1

   a+=b;       cout<a=a+b = 9+4 =13

   a*=c-50;  cout<a=a*(c-50)=13*(90-50)=520

   a-=38;      cout<a=a-38=520-38=482

   a%=8;     cout<a=a%8=482%8=2

   return 0;

}

 


5. Inkrement va dekrement amallar. Razryadli mantiqiy amallar. Chapga va o‘ngga surish amallari.

Inkrement va dekrement amallari

С++ tilida operand qiymatini birga oshirish va kamaytirish-ning samarali vositalari mavjud. Bular inkrement (++) va dekre­ment (--) unar amallardir.

Operandga nisbatan bu amallarning prefiks va postfiks ko‘ri-nishlari bo‘ladi. Prefiks ko‘rinishda amal til ko‘rsatmasi bo‘yicha ish bajarilishidan oldin operandga qo‘llaniladi. Postfiks holatda esa amal til ko‘rsatmasi bo‘yicha ish bajarilgandan keyin operandga qo‘llaniladi.

Prefiks yoki postfiks amal tushunchasi faqat qiymat berish bilan bogʻliq ifodalarda o‘rinli:



x=y++;           // postfiks

index =--i;      // prefiks

count++;        // unar amal, ”++count;” bilan ekvivalent

abc-- ;           // unar amal, ”--abc; ” bilan ekvivalent

Bu yerda y o‘zgaruvchining qiymatini x o‘zgaruvchisiga o‘zlashtiri-ladi va keyin bittaga oshiriladi, i o‘zgaruvchining qiymati bittaga kamaytirib, index o‘zgaruvchisiga o‘zlashtiriladi.



Razryadli mantiqiy amallar

Dastur tuzish tajribasi shuni ko‘rsatadiki, odatda qo‘yilgan masalani yechishda biror holat ro‘y bergan yoki yo‘qligini ifodalash uchun 0 va 1 qiymat qabul qiluvchi bayroqlardan foydala-niladi. Bu maqsadda bir yoki undan ortiq baytli o‘zgaruvchilardan foydalanish mumkin. Masalan, bool turidagi o‘zgaruvchini shu maqsadda ishlatsa bo‘ladi. Boshqa tomondan, bayroq sifatida bayt-ning razryadlaridan foydalanish ham mumkin. CHunki razryadlar faqat ikkita qiymatni - 0 va 1 sonlarini qabul qiladi. Bir baytda 8 razryad bo‘lgani uchun unda 8 ta bayroqni kodlash imkoniyati mavjud.

Faraz qilaylik, qo‘riqlash tizimiga 5 ta xona ulangan va tizim taxtasida 5 ta chiroqcha (indikator) xonalar holatini bildiradi: xona qo‘riqlash tizimi nazoratida ekanligini mos indikatorning yonib turishi (razryadning 1 qiymati) va xonani tizimga ulanmagan-ligini indikator o‘chganligi (razryadning 0 qiymati) bildiradi. Tizim holatini ifodalash uchun bir bayt etarli bo‘ladi va uning kichik razryadidan boshlab beshtasini shu maqsadda ishlatish mumkin:


7

6

5

4

3

2

1

0

 

 

 

ind5

ind4

ind3

ind2

ind1

 

Masalan, baytning quyidagi holati 1, 4 va 5 xonalar qo‘riqlash tizimiga ulanganligini bildiradi:

 


7

6

5

4

3

2

1

0

х

х

х

1

1

0

0

1

 

Quyidagi jadvalda С++ tilida bayt razryadlari ustida mantiqiy amallar majmuasi keltirilgan.

 

 

1.5-jadval. Bayt razryadlari ustida mantiqiy amallar



Amallar

Mazmuni

&

Mantiqiy VA (ko‘paytirish)

|

Mantiqiy YOKI (qo‘shish)

^

Istisno qiluvchi YOKI

~

Mantiqiy INKOR (inversiya)

Razryadli mantiqiy amallarning bajarish natijalarini jadval ko‘rinishida ko‘rsatish mumkin.

1.6-jadval. Razryadli mantiqiy amallarning bajarish natijalari



A

B

C=A&B

C=A|B

C=A^B

C=~A

0

0

0

0

0

1

0

1

0

1

1

1

1

0

0

1

1

0

1

1

1

1

0

0

YUqoridagi keltirilgan misol uchun qo‘riqlash tizimini ifodalovchi bir baytli char turidagi o‘zgaruvchini e’lon qilish mumkin:

         char q_taxtasi=0;

Bu yerda q_taxtasi o‘zgaruvchisiga 0 qiymat berish orqali barcha xonalar qo‘riqlash tizimiga ulanmaganligi ifodalanadi:


7

6

5

4

3

2

1

0

0

0

0

0

0

0

0

0

Agar 3-xonani tizimga ulash zarur bo‘lsa

          q_taxtasi=q_taxtasi|0x04;

amalini bajarish kerak, chunki 0x0416=000001002 va mantiqiy YOKI amali natijasida q_taxtasi o‘zgaruvchisi bayti quyidagi ko‘rinishda bo‘ladi:


7

6

5

4

3

2

1

0

0

0

0

0

0

1

0

0

Xuddi shunday yo‘l bilan boshqa xonalarni tizimga ulash mumkin, zarur bo‘lsa birdaniga ikkitasini (zarur bo‘lsa barchasini):

            q_taxtasi=q_taxtasi|0x1F;

Mantiqiy ko‘paytirish orqali xonalarni qo‘riqlash tizimidan chiqarish mumkin:

            q_taxtasi=q_taxtasi&0xFD;       // 0xFD16=111111012

Xuddi shu natijani ‘~’ amalidan foydalangan holda ham olish mumkin. Ikkinchi xona tizimga ulanganligi bildiruvchi bayt qiymati - 000000102, demak shu holatni inkor qilgan holda mantiqiy ko‘paytirishni bajarish kerak.

           q_taxtasi=q_taxtasi&(~0x02);

Va nihoyat, agar 3-xona indikatorini, uni qanday qiymatda bo‘lishidan qat’iy nazar qarama-qarshi holatga o‘tkazishni «inkor qiluvchi YOKI» amali yordamida bajarish mumkin:

             q_taxtasi=q_taxtasi^0x04;        // 0x0416=000001002

Razryadli mantiqiy amallarni qiymat berish operatori bilan birgalikda bajarilishining quyidagi ko‘rinishlari mavjud:

&= - razryadli VA qiymat berish bilan;

 | = - razryadli YOKI qiymat berish bilan;

 ^= - razryadli istisno qiluvchi YOKI qiymat berish bilan.

 

Chapga va o‘ngga surish amallari

Baytdagi bitlar qiymatini chapga yoki o‘ngga surish uchun, mos ravishda “<<” va “>>” amallari qo‘llaniladi. Amaldan keyingi son  bitlar nechta o‘rin chapga yoki o‘nga surish kerakligini bildiradi.

Masalan:

unsigned char A=12;                // A=000011002=0x0C16

A=A<<2;                                   // A=001100002=0x3016=4810

A=A>>3;                                  // A=000001102=0x0616=610

Razryadlarni n ta chapga (o‘nga) surish sonni 2n soniga ko‘paytirish (bo‘lish) amali bilan ekvivalent bo‘lib va nisbatan tez bajariladi. Shuni e’tiborga olish kerakki, operand ishorali son bo‘lsa, u holda chapga surishda eng chapdagi ishora razryadi takrorlanadi (ishora saqlanib qoladi) va manfiy sonlar ustida bu amal bajarilganda matematika nuqtai-nazardan xato natijalar yuzaga keladi:



char B=-120;                           // B=100010002=0x8816

B=B<<2;                                  // B=001000002=0x2016=3210

B=-120;                                    // B=100010002=0x8816

B=B>>3;                                  // B=111100012=0xF116=-1510

Shu sababli, bu razryadli surish amallari ishorasiz (unsigned) turdagi qiymatlar  ustida bajarilgani ma’qul.



Taqqoslash amallari

С++ tilida qiymatlarni solishtirish uchun taqqoslash amallari aniqlangan (3.3-jadval). Taqqoslash amali binar amal bo‘lib, quyidagi ko‘rinishga ega:



1> < operand2>

Taqqoslash amallarining natijasi - taqqoslash o‘rinli bo‘lsa, true (rost), aks holda false (yolgʻon) qiymat bo‘ladi. Agar taqqoslashda arifmetik ifoda qatnashsa, uning qiymati 0 qiymatidan farqli holatlar uchun 1 deb hisoblanadi.

1.7-jadval. Taqqoslash amallari va ularning qo‘llanishi


Amallar

Qo‘llanishi

Mazmuni (o‘qilishi)



A

“a kichik b”

<=

a<=b

“a kichik yoki teng b”



a>b

“a katta b”

>=

a>=b

“a katta yoki teng b”

==

a==b

“a teng b”

!=

a!=b

“a teng emas b”

 «Vergul» amali

Til qurilmalaridagi bir nechta ifodalarni kompilyator tomonidan yaxlit bir ifoda deb qabul qilishi uchun «vergul» amali qo‘llaniladi. Bu amalni qo‘llash orqali dastur yozishda ma’lum bir samaradorlikka erishish mumkin. Odatda «vergul» amali if va for operatorlarida keng qo‘llaniladi. Masalan, if operatori qo‘yidagi ko‘rinishda bo‘lishi mumkin:



if(i=CallFunc(),i<7)...

Bu yerda, oldin CallFunc() funksiyasi chaqiriladi va uning natijasi i o‘zgaruvchisiga o‘zlashtiriladi, keyin i qiymati 7 bilan solishtiriladi.

 

Shartli amal

Shartli amal ternar amal deyiladi va uchta operanddan iborat bo‘ladi:

          <1-ifoda>?<2-ifoda>:<3-ifoda>

Shartli amal bajarilganda avval 1- ifoda hisoblanadi. Agar 1-ifoda qiymati 0 dan farqli bo‘lsa 2- ifoda hisoblanadi va qiymati natija sifatida qabul qilinadi, aks holda 3-ifoda hisoblanadi va qiymati natija sifatida qabul qilinadi.



Misol uchun modulni hisoblash: x<0?-x:x yoki ikkita sondan kichigini topish a

6. Amallar bajarish ketma-ketligi va yo’nalishi.

Quyidagi jadvalda С++ tilida ishlatiladigan amallar (operatorlar), ularning ustunlik koeffitsientlari va bajarilish yo‘nalishlari (Ü - o‘ngdan chapga, Þ - chapdan o‘ngga) keltirilgan.



1.8-jadval. Amallarning ustunliklari va bajarilish yo‘nalishlari

Operator

Tavsifi

Ustunlik

Yo‘nalish

::

Ko‘rinish sohasiga ruxsat berish

16

Þ

[ ]

Massiv indeksi

16

Þ

  (  )

Funksiyani chaqirish

16

Þ

.

Struktura yoki sinf elementini tanlash

16

Þ

->

++

Postfiks inkrement

15

Ü

- -

Postfiks dekrement

15

Ü

++

Prefiks inkrement

14

Ü

- -

Prefiks dekrement

14

Ü

sizeof

O‘lchamni olish

14

Ü

()

Turga akslantirish

14

 

~

Razryadli mantiqiy INKOR

14

Ü

!

Mantiqiy inkor

14

Ü

-

Unar minus

14

Ü

+

Unar plyus

14

Ü

&

Adresni olish

14

Ü

*

Vositali murojaat

14

Ü

new

Dinamik ob’ektni yaratish

14

Ü

delete

Dinamik ob’ektni yo‘q qilish

14

Ü

casting

Turga keltirish

14

 

*

Ko‘paytirish

13

Þ

/

Bo‘lish

13

Þ

%

Bo‘lish qoldigʻi

13

Þ

+

Qo‘shish

12

Þ

-

Ayirish

12

Þ

>> 

Razryad bo‘yicha o‘ngga surish

11

Þ

<< 

Razryad bo‘yicha chapga surish

11

Þ



Kichik

10

Þ

<=

Kichik yoki teng

10

Þ



Katta

10

Þ

>=

Katta yoki teng

10

Þ

==

Teng

9

Þ

!=

Teng emas

9

Þ

&

Razryadli VA

8

Þ

^

Razryadli istisno qiluvchi YOKI

7

Þ

|

Razryadli YOKI

6

Þ

&&

Mantiqiy VA

5

Þ

| |

Mantiqiy YOKI

4

Þ

?:

SHart amali

3

Ü

=

Qiymat berish

2

Ü

*=

Ko‘paytirish qiymat berish bilan

2

Ü

/=

Bo‘lish qiymat berish bilan

2

Ü

%=

Modulli bo‘lish qiymat berish bilan

2

Ü

+=

Qo‘shish qiymat berish bilan

2

Ü

- =

Ayirish qiymat berish bilan

2

Ü

<<=

CHapga surish qiymat berish bilan

2

Ü

>>=

O‘ngga surish qiymat berish bilan

2

Ü

&=

Razryadli VA qiymat berish bilan

2

Ü

^=

Razryadli istisno kiluvchi YOKI qiymat berish bilan

2

Ü

| =

Razryadli YOKI qiymat berish bilan

2

Ü

throw

Istisno holatni yuzaga keltirish

2

Ü

,

Vergul

1

Þ

С++ tili dastur tuzuvchisiga amallarning bajarilish tartibini o‘zgartirish imkoniyatini beradi. Xuddi matematikadagidek, amallarni qavslar yordamida guruhlarga jamlash mumkin. Qavs ishlatishga cheklov yo‘q.

Quyidagi dasturda qavs yordamida amallarni bajarish tartibini o‘zgartirish ko‘rsatilgan.



#include

int main(){int x=0, y=0;  int a=3, b=34, c=82;  x=a*b+c;

 y=(a*(b+c));  cout<<”x= ”<

Dasturda amallar ustunligiga ko‘ra x qiymatini hisoblashda oldin a o‘zgaruvchi b o‘zgaruvchiga ko‘paytiriladi va unga c o‘zgaruvchi qiymatiga qo‘shiladi. Navbatdagi ko‘rsatmani bajarishda esa birinchi navbatda ichki qavs ichidagi ifoda - (b+c) qiymati hisoblanadi, keyin bu qiymat a ko‘paytirilib, u o‘zgaruvchisiga o‘zlashtiriladi. Dastur bajarilishi natijasida ekranga

x=184 y=348

satrlari chop etiladi.



7. C++ da kutbhonalar. Standart matematik funktsiyalar kutubhonasi.

C++ tilida dasturning tuzilishiga, ya’ni ehtiyojiga qarab, kerakli kutubhona faylini preprotsessor include direktivasi yordamida qo’shib olishimiz mumkin. Ular < > belgisi orasida keltiriladi.  Masalan:



#include

 Umuman olganda quyidagi direktivalar mavjud (jami 32 ta):



  1. #include  - C tilida kiritish/chiqarish.

  2. #include  - C++ tilida kiritish / chiqarish

  3. #include  - standart matematik funksiyalar uchun

  4. #include  - kiritish/chiqarishni nazorat qilish

  5. #include  - qator tipli o’zgaruvchilar bilan ishlash

  6. #include  - standart kutubxona fayllarini chaqirish

  7. # include  - kompyuterning soatidan foydalanish

  8. #include  - grafik imkoniyatlaridan foydalanish

 Bu fayllar maxsus kutubxona e’lon fayllari hisoblanadilar va ular aloxida INCLUDE deb nomlanadigan papkada saqlanadiar. Hozirda C++ kutubxonasini yangilandi va undagi fayllarning nomlaridan .h (head – bosh ma’nosida) kengaytmasi olib tashlandi va oldiga c harfi qo’shildi (C dan qolgan 18 tasiga). Bu fayllarda funksiya prototoifalari, toifalari, o’zgaruvchilar, o’zgarmaslar ta’riflari yozilgan bo’ladi.

Ko’pgina ifodalarda (formulalarda) matematik funktsilar  qatnashadi. Ularning qiymatini hisoblash uchun C++ da  matematik standart funktsiyalar kutubhonasi math mavjud. Unda joylashgan funktsiyalardan dasturimizda foydalanish uchun  #include      yoki  yangi versiyalarda #include  direktivasi yordamida dasturimizga qo’sdib olisdimiz kerak. Quyida (1/9 – jadvalda) shu kutubhona funktsiyalarning nomi (C++ da yozilishi) keltirilgan.

 


Funksiya

(matematikada)



Yozilishi

(C++ da)


Funksiya

(matematikada)



Yozilishi

(C++ da)


sin x

sin(x)




sqrt (x);  pow(x,1./2)

cos x

cos(x)




abs(x);

 fabs(x)



tg  x

tan(x)

arctan x

atan (x)

ln x

log(x)




pow(x, 2./3)

lg x

log10(x)




log(x)/log(2); log2(x)

xa

pow(x,a)




exp(x)

Qo’shimcha standart funktsiyalar

ceil(x) -  x ni o’zidan katta yoki teng bo’lgan butun songacha yaxlitlash.

Masalan:    ceil (12.6) = 13;     ceil (-2.4)= -2;

floor (x) – x ni o’zidan kichik yoki teng bo’lgan butun songacha yaxlitlash.

Masalan:    floor (12.1) = 12;    floor (4.8) = 4;

                    floor(-12.1) = -13;  floor (15.9)=15;



fmod (x,y) – x/y ning qoldig’ini kasr son ko’rinishida beradi.

Masalan:  fmod (7.3,1.7) = 0.5

8.Nazorat savollari


             1.       Algoritm. Algoritm ta’rifi. Algoritm tafsiflash usullari.

             2.       Algoritm. Algoritm hossalari.

             3.       Algoritmlarning asoaiy (basoviy) turlarini sanab o’ting.

             4.       C / C ++ tilidagi dasturning tuzilishi. Oddiy dasturga misol.

             5.       C++ alifbosi. Leksemalar.

             6.       C++ izoh. Ularning turlari. Misollar keltiring.

             7.       C+da o’zgarmas kattaliklar. Ularning turlari. Misollar keltiring.

             8.       Ma'lumot turlari nima va ularning qanday turlarini bilasiz?

             9.       Identifikator tushunchasi. O’zgaruvchilarga nom berish qoidalari.

           10.      Identifikatorlar va kalit so’zlari.

           11.      Aritmetik amallar. Arifmetik ifodalar. Ularga misollar keltiring.

           12.      Oddiy solishtirish amallari. Ularga misollar keltiring.

           13.      Mantiqiy iboralar qanday yoziladi?

           14.      Ma'lumotlarning standart turlari. Xarakteristikalar jadvali.

           15.      O'zgaruvchilar. Initsializatsiya deganda nima tushiniladi?

           16.      Konstantalar. Maxsus belgilar.

           17.      Konstantalar. Butun son ko’rinishidagi o’zgarmas kattaliklar.

           18.      Konstantalar. Haqiqiy son ko’rinishidagi o’zgarmas kattaliklar.

           19.      C++ da qiymat berish operatorlari ( misollar).

           20.      Preprosessor ko'rsatmalari, sarlavha fayllari.

           21.       Dasturda o'zgaruvchini aniqlash. O'zgaruvchilarning tayanch turlari.

           22.      C++ da inkrement va decrement amallari

           23.      C++ da unar amallar. Razryadli mantiqiy amallar

           24.      С++ tilining tayanch turlari

           25.      C++ da unar amallar. Chapga va o‘ngga surish amallari.

           26.      C++ da unar amallar. Inkrement va dekrement amallari.

           27.      C++ da shartli amal.

           28.      C++ da binar amallar. Qoldiqli bo’lish amali.

           29.      Arifmetik amallarning bajarish tartibi va yo’nalishi.

           30.      Mantqiy ifodalarda amallarning bajarish tartibi va yo’nalishi.



           31.      Standart mateamatik funktsiyalar kutubxonasi.

           32.      Aniq va yashirin turdagi toifani o’zgartirish

Download 63.29 Kb.

Do'stlaringiz bilan baham:
1   2   3




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©fayllar.org 2024
ma'muriyatiga murojaat qiling