aboutsummaryrefslogtreecommitdiff
path: root/week07/README.md
blob: ea642128f60160be78b0430c3387881e4264282b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
# Задачи - ООП, Седмица 7, 04.04.2024

*Този файл е копие на задачите от: [syndamia.com/teaching/oop-2023/week7](https://syndamia.com/teaching/oop-2023/week7)*

## Преговорни

### Задача 1 - Голяма петица

Една съставка е композирана от низ (с максимална дължина от 511 знака) определящ името ѝ и грамаж (число с плаваща запетая).

Създайте клас `Recipe`, към който могат да се прибавят и премахват произволен брой съставки.
Имплементирайте голяма петица (голяма четворка плюс move семантики) за него.

### Задача 2 - Работа с файлове

От един ред на входа получавате името на текстови файл.
Изкарайте на екрана средната една трета от файла, като буквите са в обратен ред.

## Лесни задачи

### Задача 3

Имплементирайте клас `Thermometer`, който запазва максималната и минималната възможна температура за измерване, както и сегашната температура, всичките които са цели неотрицателни числа.

Имплементирайте методи `SaveText` и `LoadText`, които съответно записват и четат (тоест член-данните стават равни на тези от файла) данните си в/от **текстови** файл с подадено име.
Аналогично имплементирайте `SaveBinary` и `LoadBinary`, които работят с **двоични** файлове.

### Задача 4

Имплементирайте клас `Street`, който запазва скрито името на улицата като низ с произволна дължина и номер като цяло число.
Имплементирайте голяма петица.

Имплементирайте методите `SaveText`, `LoadText`, `SaveBinary`, `LoadBinary`.

### Задача 5

За един транспортен билет е нужно скрито да пазим началната и крайната дестинация като динамично-заделени низове с произволна дължина, неговата цена като число с плаваща запетая и идентификационен номер като цяло неотрицателно число.

Имплементирайте голяма петица и четирите функции за запазване и четене от файлове на съответния клас.

### Задача 6

Имплементирайте клас `Matrix`, който запазва стойностите на матрица 2 на 2.
Предефинирайте операторите за инкрементиране, декрементиране, събиране, изваждане, умножение и вход/изход от/към поток.

Имплементирайте четирите функции за записване и четене от файлове.

### Задача 7

Имплементирайте клас `Paragraph`, който съдържа текст с много редове в него.
Текстът се запазва като низ с произволна дължина, а редовете се разделят със знака `'\n'`.

Имплементирайте голяма петица.
Имплементирайте четирите функции за записване и четене от файлове.

Имплементирайте операторите за събиране, които копират текстът от подадения параграф и го вмъкват в края на сегашния; оператор[] който връща начален указател на i-тия ред; операторите за (лексикографско) сравнение; вход/изход от/към поток.

## Трудни задачи

### Задача 8

Имплементирайте клас `MatrixNМ`, който запазва стойностите на матрица с N реда и M колони (подадени на конструктор).

Имплементирайте голяма петица.
Имплементирайте четирите функции за записване и четене от файлове.

Имплементирайте операторите за събиране, изваждане, умножение и деление (нека да дефинираме деление на две матрици като умножението на първата матрица по транспонираната втората матрица върху детерминантата ѝ).
Ако някоя операция не е възможна, върнете съответна стойност по подразбиране.

Имплементирайте оператор[], като индекса i е числена конкатенация на двете координати, разделени с нула (тоест ако искаме стойността на ред 27 и колона 9, тогава ще въведем индекса 2709).
Имплементирайте оператори за равенство, инкрементиране, декрементиране, побитово отместване (прилага се върху всяка стойност в матрицата), логически (&& връща true само ако двете матрици са равни, || връща true ако имат еднакви размерности и съществува поне един равен елемент на еднакви индекси).