Базовые понятия

Алгоритм – вычислительная процедура.

Контейнер – класс, управляющий набором объектов в памяти.

Итератор – прослойка между конкретным контейнером и обобщенным алгоритмом.

Функциональный объект / функтор / - инкапсулирует функцию в объекте для использования другими. Лямбда-выражение – анонимный функтор со специальным синтаксисом.

Контейнеры

В контейнерах можно выделить основные используемые типы данных: пара, вектор, список, очередь, стек, словарь.

Простые контейнеры

2.1.1 Пара (Pair / Tuple)

Пара значений состоит из двух связанных как-то значений. Часто бывает лениво плодить отдельную структуру или класс только для того, чтобы объединить данные, списками которых обмениваются подпрограммы (смотрите подпрограмму в примере, типичный случай)… Когда количество данных невелико, используются пары. Пара агрегирует 2 значения и предоставляет к ним доступ.

Примеры создания пар ниже.

#include "stdafx.h"

#include <utility>

#include <vector>

using namespace std;

vector<pair<int, int> > GetPoints()

{

vector<pair<int, int> > points;

points.push_back(make_pair(1, 1));

points.push_back(make_pair(1, 3));

points.push_back(make_pair(2, 4));

return points;

}

int _tmain(int argc, _TCHAR* argv[])

{

pair <int, int> point(13, 555); // конструкторы инициализации

pair <int, int> point2; // по-умолчанию

pair <int, int> point3(point); // копирования

auto point4 = make_pair(3, 4); // pair <int, int> point(3, 4);

auto points = GetPoints();

return 0;

}

Зачем добавили make_pair подпрограмму?

Чтобы не писать явно типы, вида pair<int, int>.

Как достать агрегированные данные?

Структура позволяет получить данные через поля first и second.

Как в дальнейшем развивался этот концепт?

Выяснилось, что иногда хочется агрегировать не 2, а больше данных: поэтому пару подогнули в других языках программирования, чтобы количество аргументов было опциональным. Также концепт переименовали в Tuple.

Насколько кошерно пользоваться парой?

Ведь исчезает смысл полей. Легко перепутать и ошибиться.

В принципе, когда передается много данных в паре, то приходится помнить, что за оно. Легко ошибиться, например, пришла пара tuple<int, int, int>(13,333,333), без просмотра исходного кода, сложно понять, какое число что обозначает. Подход: если где-то в одном месте это понадобилось сделать – то это еще ничего, а если внутри системы циркулируют только пары, то это некошерно: тяжело читать код, лучше завести структуру.

Контейнеры с последовательным доступом

Популярны vector, list. Остальные типы практически не используются и будут лишь упомянуты.

Наши рекомендации