Axborot texnologiyalari va kommunikatsiyalarini rivojlantirish vazirligi muso al-xorazmiy nomidagi toshkent axborot texnologiyalari universiteti urganch filiali 963/21-guruh Kiberxavfsizlik asoslari kafedrasi Kiberxavfsizlik asoslari fa’nidan mustaqil ish



Download 29,5 Kb.
bet1/4
Sana14.12.2022
Hajmi29,5 Kb.
#885633
  1   2   3   4
Bog'liq
MASSIVLARNI TASHKIL ETISH


AXBOROT TEXNOLOGIYALARI VA KOMMUNIKATSIYALARINI RIVOJLANTIRISH VAZIRLIGI MUSO AL-XORAZMIY NOMIDAGI TOSHKENT AXBOROT TEXNOLOGIYALARI UNIVERSITETI URGANCH FILIALI 963/21-guruh

Kiberxavfsizlik asoslari kafedrasi
Kiberxavfsizlik asoslari fa’nidan

MUSTAQIL ISH
Mavzu: MASSIVLARNI TASHKIL ETISH

Bajardi: Mamatsaliev. X.

Tekshirdi: MASHARIPOV. S.

Urganch 2022
Reja

  1. Kirish.

  2. Asosiy qism.

2.1. Berilganlar massivi tushunchasi.
2.2. Bir o’lchamli massivlar va ko’p o’lchamli massivlar.
2.3 Dinamik massivlar bilan ishlash.

  1. Yakuniy qism.

Foydalanilgan adabiyotlar.


KIRISH
Massiv bu bir tipli nomerlangan ma’lumotlar jamlanmasidir. Massiv indeksli o‘zgaruvchi tushunchasiga mos keladi. Massiv ta’riflanganda tipi, nomi va indekslar chegarasi ko‘rsatiladi. Masalan type turidagi length ta elementdan iborat a nomli massiv shunday e’lon qilinadi:
type a[length];
Bu maxsus a[0], a[1], ..., a[length -1] nomlarga ega bo‘lgan type turidagi o‘zgaruvchilarning e’lon qilinishiga to‘g‘ri keladi.
Massivning har bir elementi o‘z raqamiga - indeksga ega. Massivning x-nchi elementiga murojaat indekslash operatsiyasi yordamida amalga oshiriladi:
int x=...; //butun sonli indeks
TYPE value=a[x]; //ch-nchi elementni o‘qish
a[x]=value; //x-yxb elementga yozish
Indeks sifatida butun tur qiymatini qaytaradigan har qanday ifoda qo‘llanishi mumkin: char, short, int, long. C++ da massiv elementlarining indekslari 0 dan boshlanadi (1 dan emas), length elementdan iborat bo‘lgan massivning oxirgi elementining indeksi esa - bu length -1 (length emas). Massivning int z[3] shakldagi ta’rifi, int tipiga tegishli z[0],z[1],z[2] elementlardan iborat massivni aniqlaydi.
Massiv chegarasidan tashqariga chiqish (ya’ni mavjud bo‘lmagan elementni o‘qish/yozishga urinish) dastur bajarilishida kutilmagan natijalarga olib kelishi mumkin. SHuni ta’kidlab o‘tamizki, bu eng ko‘p tarqalgan xatolardan biridir.
Agar massiv initsializatsiya qilinganda elementlar chegarasi ko‘rsatilgan bo‘lsa , ro‘yxatdagi elementlar soni bu chegaradan kam bo‘lishi mumkin, lekin ortiq bo‘lishi mumkin emas.
Misol uchun int a[5]={2,-2}. Bu holda a[0] va a[1] qiymatlari aniqlangan bo‘lib, mos holda 2 va –2 ga teng. Agar massiv uzunligiga qaraganda kamroq element berilgan bo‘lsa, qolgan elementlar 0 hisoblanadi:
int a10[10]={1, 2, 3, 4}; //va 6 ta nol
Agar nomlangan massivning tavsifida uning o‘lchamlari ko‘rsatilmagan bo‘lsa, kompilyator tomonidan massiv chegarasi avtomatik aniqlanadi:
int a3[]={1, 2, 3};

Berilganlar massivi tushunchasi - [1(260-263), 2(112), 3(87-90)]Xotirada ketma-ket (regular) joylashgan bir xil turdagi qiymatlarga massiv deyiladi.


Odatda massivlarga zarurat, katta hajmdagi, lekin cheklangan miqdordagi va tartiblangan qiymatlarni qayta ishlash bilan bog‘liq masalalarni yechishda yuzaga keladi. Faraz qilaylik, talabalar guruhining reyting ballari bilan ishlash masalasi qo‘yilgan. Unda guruhning o‘rtacha reytingini aniqlash, reytinglarni kamayishi bo‘yicha tartiblash, konkret talabaning reytingi haqida ma’lumot berish va boshqa masala ostilarini yechish zarur bo‘lsin. Qayd etilgan masalalarni yechish uchun berilganlarning (reytinglarning) tartiblangan ketma-ketligi zarur bo‘ladi. Bu yerda tartiblanganlik ma’nosi shundaki, ketma-ketlikning har bir qiymati o‘z o‘rniga ega bo‘ladi (birinchi talabaning reytingi massivda birinchi o‘rinda, ikkinchi talabaniki – ikkinchi o‘rinda va hakoza). Berilganlar ketma-ketligini ikki xil usulda hosil qilish mumkin. Birinchi yo‘l – har bir reyting uchun alohida o‘zgaruvchi aniqlash: Reyting1, Reyting2,… ReytingN. Lekin ,guruhdagi talabalar soni yetarlicha katta bo‘lganda, bu o’zgaruvchilar qatnashgan programmani tuzish katta qiyinchiliklarni yuzaga keltiradi. Ikkinchi yo‘l – berilganlar ketma-ketligini yagona nom bilan aniqlab, uning qiymatlariga murojaatni, shu qiymatlarning ketma-ketlikda joylashgan o‘rnining nomeri (indeksi) orqali amalga oshirishdir. Reytinglar ketma-ketligini Reyting deb nomlab, undagi qiymatlariga Reyting, Reyting,… Reyting ko‘rinishida murojaat qilish mumkin. Odatda berilganlarning bunday ko‘rinishiga massivlar deyiladi. Massivlarni matematikadagi sonlar vektoriga o’xshatish mumkin, chunki vektor ham o‘zining individual nomiga ega va u fiksirlangan miqdordagi bir turdagi qiymatlardan – sonlardan iboratdir.
Demak, massiv – bu fiksirlangan miqdordagi ayrim qiymatlarning (massiv elementlarining) tartiblangan majmuasidir. Barcha elementlar bir xil turda bo‘lishi kerak va bu tur element turi yoki massiv uchun tayanch tur deb nomlanadi. Yuqoridagi keltirilgan misolda Reyting – haqiqiy turdagi vektor deb nomlanadi.
Programmada ishlatiladigan har bir konkret massiv o‘zining individual nomiga ega bo‘lishi kerak. Bu nomni to‘liq o‘zgaruvchi deyiladi, chunki uning qiymati to‘liq bir massivning o‘zi bo‘ladi. Massivning har bir elementi massiv nomi, hamda kvadrat qavsga olingan va element selektori deb nomlanuvchi indeksni ko‘rsatish orqali oshkor ravishda belgilanadi. Murojaat sintaksisi:
[]
Bu ko‘rinishga xususiy o‘zgaruvchi deyiladi, chunki uning qiymati massivning alohida elementidir, Bizning misolda Reyting massivining alohida komponentalariga Reyting[1], Reyting[2],..., Reyting[N] xususiy o‘zgaruvchilar orqali murojaat qilish mumkin. Boshqacha bu o‘zgaruvchilarni indeksli o‘zgaruvchilar deyiladi.
Umuman olganda indeks sifatida ifoda ishlatilishi mumkin. Ifoda qiymati massiv elementi nomerini aniqlaydi. Ifoda sifatida o‘zgaruvchi ham olinishi mumkinki, o‘zgaruvchining qiymati o‘zgarishi bilan murojaat qilinayotgan massiv elementini aniqlovchi indeks ham o‘zgaradi. Shunday qilib, programmadagi bitta indeksli o‘zgaruvchi orqali massivning barcha elementlarini belgilash (aniqlash) mumkin. Masalan, Reyting[1] o‘zgaruvchisi orqali I o‘zgaruvchining qiymatiga bog‘liq ravishda Reyting massivining turli (barcha) elementlariga murojaat qilish imkoni mavjud. Shuni qayd qilish kerakki, massiv indeksi sifatida butun son qo‘llaniladi.

Haqiqiy turdagi (float,double) qiymatlar to‘plami cheksiz bo‘lganligi sababli ular indeksi sifatida ishlatilmaydi.


C++ tilida indeks doimo 0 dan boshlanadi, uning eng katta qiymati massiv e’lonidagi uzunlikdan bittaga kam bo‘ladi.
Massiv e’loni quyidagicha bo‘ladi:
[]={boshlang‘ich qiymatlar}
Bu yerda - o‘zgarmas ifoda. Misollar:
int m[6]={1,4,-5,2,10,3] ;
float a[4] ;
Massiv statik va dinamik bo‘lishi mumkin, Statik massivning uzunligi oldindan ma’lum bo‘lib, u xotirada ma’lum adresdan boshlab ketma-ket joylashadi. Dinamik massivni uzunligi programma bajarilish jarayonida aniqlanib, u dinamik xotiradagi ayni paytda bo‘sh bo‘lgan adreslarga joylashadi. Masalan,

int m[6] ;

ko‘rinishida e’lon qilingan bir o‘lchamli massiv elementlari xotirada quyidagicha joylashadi:
Adres Qiymatlar;

M m[0] m[1] m[2] m[3] m[4] m[5]


7.1-rasm. Bir o‘lchamli massivning xotiradagi joylashuvi

Massivning i- elementiga m[i] yoki *(m+i) – vositali murojaat qilish mumkin. Massiv uzunligini sizeof(m) amali orqali aniqladi.


Massiv e’lonida uning elementlariga boshlang‘ich qiymatlar olish (initsializatsiyalash) mumkin va uning bir nechta variantlari mavjud.
1)O’lchami ko‘rsatilgan massiv elementlarini to‘liq initsializatsiyalash:
int t[5]={-10,5,15,4,3};
Bunda 5 ta elementdan iborat bo‘lgan t nomli bir o‘lchamli massiv e’lon qilingan va uning barcha elementlariga boshlang‘ich qiymatlar berilgan. Bu e’lon quyidagi e’lon bilan ekvivalent:
int t[5];
t[0]=-10; t[1]=5; t[2]=15; t[3]=4; t[4]=3;
O‘lchami ko‘rsatilgan massiv elementlarini to‘liqmas initsializatsiyalash:
int t={-10,5,15};
Bu yerda faqat massiv boshidaga uchta elementga boshlang‘ich qiymatlar berilgan. Shuni aytib o‘tish kerakki, massivning boshidagi yoki o‘rtadagi ementlariga qiymatlar bermasdan, uning oxiridagi elementlarga boshlang‘ich qiymat berish mumkin emas. Agarda massiv elementlariga boshlang‘ich qiymat berilmasa, unda kelishuv bo‘yicha static va extern modifikatori bilan e’lon qilingan massiv uchun elementlarining qiymati 0 soniga teng deb, automatic massivlar elementlarining boshlang‘ich qiymatlari noma’lum hisoblanadi.
3)O‘lchami ko‘rsatilmagan massiv elementlarini to‘liq initsializatsiyalash:
int t={-10,5,15,4,3};
Bu misolda massivni barcha elementlariga qiymatlar berilgan hisoblanadi, massiv uzunligi kompilyator tomonidan boshlang‘ich qiymatlar soniga qarab aniqlanadi. Agarda massivni uzunligi berilmasa, boshlang’ich qiymati berilishi shart.
Massivni e’lon qilish misollari:

char ch={ ‘a’ , ‘b’,’c’,’d’}; //belgilar massivi

int in ={10,20,30,40}; // butun sonlar massivi

char str[]=”abcd”; //satr uzunligi 5 ga teng, chunki

//uning oxiriga ‘\0’ belgisi qo‘shiladi

char str[]={‘a’ , ‘b’ , ‘c’ ,’d’}; // yuqoridagi satrning

// boshqacha yozilishi

Masala. Bir oy ichidagi kundalik harorati berilgan, oy uchun o’rtacha haroratni hisoblash programmasi tuzilsin.


Programma matni:
void main()
{const int n=30;
int temp[n];
int I,s,temp_urtacha;
cout<<”Kunlik haroratni kiriting:\n”
for(i=0; i
{cout<<”\n temp[“<
cin>>temp[i]; }

for (i=0; i


cout<<”Kunlik harorat:\n”;
for(i=0; i
cout<<”Oydagi o’rtacha harorat=”<
return;
}


Download 29,5 Kb.

Do'stlaringiz bilan baham:
  1   2   3   4




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
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