2-topshiriq
Iteratorlar va ularning qo‘llanilishi. Xotirani taqsimlovchilar va ularga
qo‘yilgan talablar
1-misol:
Standart algoritmlar va iteratorlardan foydalanib,
amaliy dasturlar yaratish
Ishning maqsadi: C++ dasturlash tilida Standart algoritmlar va iteratorlar
sinflari va uning qayta yuklangan turlaridan foydalanish ko‘nikmalarini egallsh.
Masalaning qo‘yilishi:
Standart algoritmlar va iteratorlar asosida yaratilgan to‘plam elementlarini
copy(from, from_end, to),
copy_if(from, from_end, to, pred),
copy_n(from, count, to),
copy_backward(from, from_end, to_end),
move(from, from_end, to),
move_backward(from, from_end, to_end),
swap_ranges(a, a_end, b),
fill(to, to_end, value), fill_n(to, n, value),
generate(to, to_end, gen),
generate(v.begin(), v.end(), rand),
generate_n(to, n, gen), reverse(begin, end),
reverse_copy(from, from_end, to),
frnd(begin, end, value),
mismatch(a, a_end, b, b_end, eq),
max_element(begin, end, comp),
min_element(begin, end, comp),
for_each(begin, end, fun),
replace(begin, end, old_val,
new_val), remove(begin, end, value),
remove_if(begin, end, pred),
sort(begin, end, comp),
iteratorlar yordamida qayta ishlash.
Masala:
Matnli faylda N ta talabaning familiyasi, ismi va yoshi yozilgan. Ushbu
ma’lumotlarni to‘plamga o‘zlashtirib yoshi bo‘yicha saralovchi dastru tuzing.
Masalani yechish g‘oyasi:
Talaba haqida har xil turdagi ma’lumotlarni boshqarish uchun “Talaba”
nomli struktura yaratiladi. istream_iterator iteratoridan foydalanib, matnli fayldan
ma’lumotlar o‘zlashtiriladi va ostream_iterator iteratoridan foydalanib,
ma’lumotlarni matnli faylga yoki natijalar oynasiga chiqarish mumkin. Yosh
bo‘yicha saralash uchun sort(), ma’lumotlarni vector ga joylashtirish uchun copy(),
ixtiyoriy yoshdan ixtiyoriy yoshgacha ma’lumotlarni chiqarish uchun copy_if()
algoritmlaridan foydalaniladi. “Talaba” sun‘iy tur bo‘lganligi uchun kiritish va
chiqarish oqimlari(>>, <<) qayta yuklanadi.
Dastur matni:
1 . #include " s td a fx .h "
2 . #include
3. #include
4 . #include < se t>
5. #include
6 . # include
7 . # include< s tr in g >
8 . # include< s td lib .h >
9 . # include
1 0 . # in c lu d e
11. using namespace System;
1 2 . using namespace s td ;
13. s t ru c t Talaba{ / / TaLaba nomli struktura
14. s t d : : s t r in g fir s tn am e , secondname;
15. s iz e _ t age;
16. } ;
17. / / "<" amallarni qayta yuklash
18. bool comparator(const Talaba& p1, const Talaba& p2) {
19. return p1.age < p2.ag e ; }
2 0 . s t d : : ostream& operator << ( s t d : : ostream& out, const
Talaba& p) {
2 1 . out << p.firs tn am e << " " << p.secondname << " " <<
p.ag e ;
2 2 . return ou t;
23. }
24. / / ">>" amallarni qayta yuklash
25. s t d : : istream& o p e r a to r > > ( s td ::istream& in , Talaba& p) {
26. in >> p.firs tn am e >> p.secondname >> p.ag e ;
27. return in ; }
28. / / standart algoritmlarda parameter uchun qocLLashga
29. s t ru c t p red ic a te {
30. s iz e _ t begin, end;
31. p r e d ic a te ( in t p1, in t p2) : b eg in (p1) , end(p2) { }
32. bool operator ( ) ( const Talaba &p) {
33. return ( p.age > begin) && ( p.age < end); }
34. } ;
35. / / Matnli faylga bocg clanish
36. void F ile _ o u t_ in ( ) {
37. s t d : : ifs tre am f i n ( " in p u t .t x t " ) ;
38. s t d : : ofstream f o u t ( "o u tp u t .tx t " ) ;
39. i f ( f in = =NULL){c o u t< < " fa y l not found"; re tu rn ; }
4 0 . s t d : :v e c to r v; / / Talaba tipida v konteyner
4 1 . / / copy aLgoritmidan foydalanib, fayLdan ma'Lumot
Dostları ilə paylaş: |