|
1- лаборатория иши
|
bet | 1/6 | Sana | 15.05.2024 | Hajmi | 184,96 Kb. | | #235793 |
Bog'liq 1.5 amaliy
O’ZBEKISTON RESPUBLIKASI RAQAMLI TEXNOLOGIYALAR
VAZIRLIGI
MUHAMMAD AL-XORAZMIY NOMIDAGI TOSHKENT AXBOROT TEXNOLOGIYALARI UNIVERSITETI
QARSHI FILIALI
___________________________________________ FAKULTETI
______________________ GURUH TALABASINING
DASTURLASH 2
FANIDAN
A M A L I Y I S H
Bajardi: __________________________________
Qabul qildi: __________________________________
QARSHI-2023
1 - AMALIY ISH
Mavzu: Tiplarni dinamik tarzda aniqlash.
Amaliy ishdan maqsad: C++ dasturlash tilida obyektga yo‘naltirilgan dasturlash tamoyilaridan foydalanib, noma’lum nomlar fazosini tashkil qilish ko‘nikmalarini shakllantirish.
Amaliy ish vazifalari:
1.1. Tiplarni dinamik tarzda aniqlash
Masalaning qo‘yilishi:
Variantda berilgan class, konstruktor va class maydonlari yordamida noma’lum nomlar fazosini yarating. Class da obyektlar massivi ustida quyidagi funksiyalarni bajaruvchi 3 ta static metod yozing:
Qidirish metodi
Saralash metodi
O‘zgartirish metodi
Masala: “talaba" nomli nomlar fazosi va unda “Talaba” classini yarating. Class maydonlari: Familiyasi, ismi, kursi, baholari, stipendiyasi. Class komponentalarini inkapsulyastiyalash, konstruktorlar va class metodlarini ishlab chiqing. Obyektlar massivini yarating va ular ustida qidirish, saralash, o‘zgartirish amallarini bajaring.
Masalani yechish g‘oyasi: talaba fazosida Talaba classi yaratiladi va undamaydonlar yopiq holda e’lon qilinadi. Konstruktor orqali talabaning familiyasi, ismi va kursi kiritiladi. Baholari massiv ko‘rinishda e’lon qilinib, tasodifiy baholar oladigan metod yoziladi. Stipendiyasini baholariga qarab belgilovchi metod ham yaratiladi.Talaba sessiyani yopganligiga qarab kursdan kursga o‘tkaziladi. Agar u 4 kurs bo‘lsa bitiruvchi ekanligi haqida xabar chiqariladi. Buning uchun Talaba classida setKurs()metodi yoziladi. main funksiyasida familiya va ism uchun string massivi tuzilib(tashqaridan kiritmaslik uchun), Talaba classiga tegishli obyektlar massivining konstruktoriga parametr sifatida beriladi va talabalar haqida ma’lumot chop etiladi.main funksiyasida obyektlar massivi ustida talaba ismi bo‘yicha qidiruvchi, familiyasibo‘yicha tartiblovchi va kursini o‘zgartiruvchi funksiyalar do‘st funksiya qilib yoziladi. Natijada funksiya ichida to‘g‘ridan to‘g‘ri murojaat etiladi. Dastur matni:
#include
#include
#include
#include
using namespace std;
namespace talaba{ // talaba nomli nonlar fazosi
class Talaba{
private: // modifikator
//yopiq maydonlar
string familiyasi, ismi;
int kursi, baholari[7]; 12. int stipendiyasi;
13. public:
14.// sinfning yopiq maydonlariga kirish uchun doist funksiyalar
15.friend void Qidirish(talaba::Talaba t[], int n);
16.friend void Saralash(talaba::Talaba t[], int n);
17.friend void Kurs_ozgartirish(talaba::Talaba t[], int n);
void set(string F, string I, int K) {
familiyasi = F;
ismi = I;
kursi = K;}
void get() {
23.cout<<”Fam: ”<24.cout<<”Ismi: ”<26.void setBaholari(int baho_soni) {
srand(time(NULL));
for (int i = 0; i
baholari[i]=rand()%6+1;
30.}}
31. void setKursi() {
32.kursi++;}
void setStipendiyasi(int baho_soni) {
int minBaho=baholari[0];
35.for (int i = 0; i
if(minBaho>baholari [i]) minBaho=baholari[i];}
switch (minBaho){
38.case 3: stipendiyasi=270000; break;
case 4: stipendiyasi=400000; break;
case 5: stipendiyasi=550000; break;
41.default:stipendiyasi=0; }} };
void Qidirish(talaba::Talaba t[], int n) {
cout<<”Qidirilayotgan talaba ismini kiriting: ”<
string s; cin>>s; bool bor=false;
for (int i = 0; i < n; i++) {
if(t[i].ismi.compare(s)==0) {bor=true;
t[i].get();} } 49.if(!bor) cout<<”Bu ismli talaba ro‘yhatda yo‘q!M<
49.cout<50. void Saralash(talaba::Talaba t[], int n) {
51.cout<<”Familiya bo‘yicha saralangan holati: \n”;
52.talaba::Talaba temp;
53.for (int i = 0; i 54. for (int j = 0; j 55if(t[i].familiyasi.compare(t[j].familiyasi)<0) {
56.temp=t[i]; t[i]=t[j]; t[j]=temp; } }}
57. for (int i = 0; i 59t[i].get(); } cout<59. void Kurs_ozgartirish(talaba::Talaba t[], int n) {
60.cout<<”Kursdan kursga o‘tganligi haqida ma’lumot:\n”;
bool bitiruvchi=false;
for (int i = 0; i
63if(t[i].stipendiyasi!=0 && t[i].kursi==4)
64. bitiruvchi=true;
65if(t[i].stipendiyasi!=0 && t[i].kursi<4)
6 6 t[i].setKursi();
67.if(!bitiruvchi) t[i].get();
68.else{
69t[i].get();
70.cout<<” Siz bitiruvchisiz!!M<71.bitiruvchi = false; } } }
72. int main(){
73.string fam[]={MXoshimov", MSaidaliyevaM, MBaxodirovM,MNishonovM};
74.string ism[]={MDostonM, "Xurshida", MTemurM, MBotirM};
75.int yoshlari[]={18,19,20,21};
76.talaba::Talaba t[100];
for (int i = 0; i <4; i++) {
t[i].set(fam [i],ism [i],yoshlari [i]);
t[i].setBaholari(4);
t[i].setStipendiyasi(4); 81t[i].get(); }
82.cout<
talaba::Qidirish(t,4);
talaba::Saralash(t,4);
talaba::Kurs_ozgartirish(t,4);
86.}
|
| |