|
Amaliy mashg‘ulot 2 Mavzu
|
bet | 2/4 | Sana | 14.05.2024 | Hajmi | 20,87 Kb. | | #233516 |
Bog'liq 2-amaliy mashg\'ulot :Array[o‘lcham] of ;
Masalan:
A,B:Array[1..100] of real;
C,A1,D:Array[1..10,1,,15] of real;
Bu erda A va B massivlari 100tadan elementga ega. C,A1,D1 massivlari esa 10x15=150 tadan elementga ega.
Massivlarni e’lon qilishdan maqsad massiv elementlari uchun kompьyuter xotirasidan joy ajratishdir.
Massiv elementlari qiymatlarini kiritish uchunssikl operatorlaridan foydalaniladi. Misol: For i:=1 to 10 do Read(A[i]);
Bu misolda A massivning 10 ta elementi qiymatini ekrandan ketma-ket kiritish kerak bo‘ladi. Xuddi shunday massiv qiymatlarini ekranga chiqarish ham mumkin. Misol: For i:=1 to 10 do Write(A[i]);
Dasturda massiv elementlarini ishlatganda ularning indeksi e’lon qilingan chegaradan chiqib ketmasligi kerak.
Massivni tartiblashtirishning bir necha usullari (algoritmlari) mavjud. Ulardan quyidagi usullarni qarab chiqamiz:
-tanlash usuli;
-almashtirish usuli.
Tanlash usuli yordamida massivni o‘sish bo‘yicha tartiblashtirish algoritmi quyidagicha:
1.Massivning birinchi elementidan boshlab qarab chiqilib eng kichik element topiladi.
2.Birinchi element bilan eng kichik element joylari almashtiriladi.
3.Ikkinchi elementidan boshlab qarab chiqilib eng kichik element topiladi.
4.Ikkinchi element bilan eng kichik element joylari almashtiriladi.
5.Bu protsess bitta oxirgi elementgacha takrorlanadi.
Bu algoritm dasturi quyidagicha bo‘ladi:
Amaliy qism
Program Sort;
Const n=5;
Var i, j, min, k, buf: Integer; a: Array[1..n] of Integer;
Begin
Writeln (‘Massivni tartiblashtirish’);
Write (n:3,’ -ta massiv elementini kiriting’);
For k:=1 to n Do Read(a[k]);
For i:=1 to n-1 Do
Begin { kichik elementni topish }
min:=i;
For j:=i+1 to n Do
Begin
If a[j]buf:=a[i]; a[i]:=a[min]; a[min]:=buf;
For k:=1 to n Do Write (a[k],’ ‘);
Writeln;
End;
End;
Writeln(`Massiv tartiblashtirildi.`);
End.
Dastur natijasi:
Massivni tartiblashtirish
5 ta massiv elementini kiriting
12 -3 56 47 10
Tartiblatirish
-3 12 56 47 10
-3 10 56 47 12
-3 10 12 47 56
-3 10 12 47 56
Massiv tartiblashtirildi.
|
| |