Библиотека STL. Отсортированные ассоциативные контейнеры. (Лекция 16)

Содержание

Слайд 2

Обеспечивают возможность быстрой выборки объектов из коллекции на основе значения ключа. Размер

Обеспечивают возможность быстрой выборки объектов из коллекции на основе значения ключа. Размер
коллекции изменяется динамически.
• set
Множество - упорядоченная коллекция уникальных элементов (ключей). Обеспечивает быструю выборку искомого ключа.
• multiset
Мультимножество – аналогично множеству, но позволяет хранить повторяющиеся (дублированные) элементы.

Компоненты STL – множества.

Слайд 3

Контейнер set используется для хранения и извлечения данных из коллекции, в которой

Контейнер set используется для хранения и извлечения данных из коллекции, в которой
значения элементов уникальны. Элементы служат в качестве ключей, в соответствии с которым данные автоматически упорядочиваются. 
Значение элемента не может быть изменено напрямую. Вместо этого используют удаление старого элемента и вставка нового.

Множество set

Слайд 4

Синтаксис определения set

template class Traits=less,
class Allocator=allocator>

Синтаксис определения set template class Traits=less , class Allocator=allocator > class set

class set

Параметры
Key тип элемента данных в множестве
Traits тип функционального объекта, который используется для сравнения элементов
(по умолчанию less)
Allocator тип аллокатора объекта для размещения
множества в памяти (по умолчанию
allocator).

Слайд 5

Пример 1
#include
#include
using namespace std;
int main()
{
set

Пример 1 #include #include using namespace std; int main() { set s1;
s1;
set::size_type i;
s1.insert(1);
s1.insert(1); // Ключи должны быть уникальными,
// поэтому дубликаты игнорируются
i = s1.count(1);
cout << “Число элементов 1: " << i << endl;
i = s1.count(2);
cout << «Число элементов 2: " << i << endl;
}

Слайд 6

Основные методы класса set

Емкость множества
empty проверка на пустоту
size количество элементов
max_size максимальное число элементов
Модификаторы
clear очистка содержимого
insert вставка

Основные методы класса set Емкость множества empty проверка на пустоту size количество
элемента
erase удаление элемента
Просмотр содержимого
count количество элементов, соотв. ключу
find поиск элемента по заданному ключу

Слайд 7

Пример 2 (начало)

#include
using namespace std;
template void print_element(const

Пример 2 (начало) #include using namespace std; template void print_element(const T& t)
T& t)
{
cout << "(" << t << ") ";
}
template void print_collection(const T& t)
{
cout << t.size() << " elements: ";
for (const auto& p : t)
{
print_element(p);
}
cout << endl;
}

Слайд 8

Пример 2 (продолжение)
template
void findit(const C& c, T

Пример 2 (продолжение) template void findit(const C& c, T val) { cout
val)
{
cout << "Поиск элемента " << val << endl;
auto result = c.find(val);
if (result != c.end())
{
cout << "Элемент найден: ";
print_element(*result);
cout << endl;
}
else
{
cout << "Элемент не найден." << endl;
}
}

Слайд 9

Пример 2 (окончание)
int main()
{
set s({ 40, 45 });

Пример 2 (окончание) int main() { set s({ 40, 45 }); cout
cout << "Исходное множество: " << endl;
print_collection(s);
s.insert(43);
s.insert(41);
s.insert(42);
s.insert(44);
s.insert(44); // попытка дублирования
cout << "Модифицированное множество: " << endl;
print_collection(s);
findit(s1, 45);
findit(s1, 6);
}

Слайд 10

Во многом аналогично множеству, но допускает хранение одинаковых элементов (дубликатов).
Синтаксис определения шаблона

Во многом аналогично множеству, но допускает хранение одинаковых элементов (дубликатов). Синтаксис определения
multiset совпадает с синтаксисом определения set.

Мультимножество (multiset)

Слайд 11

Пример 3 (multiset)

#include
#include
using namespace std;
int main()
{

Пример 3 (multiset) #include #include using namespace std; int main() { multiset

multiset ms;
ms.insert(1);
ms.insert(1);
ms.insert(2);
cout << "Элементов 1: " << ms.count(1) << endl;
cout << "Элементов 2: " << ms.count(2) << endl;
cout << "Элементов 3: " << ms.count(3) << endl;
}

Слайд 12

Множества часто используются в ситуациях, когда необходимо быстро определить наличие заданного элемента

Множества часто используются в ситуациях, когда необходимо быстро определить наличие заданного элемента
в наборе (есть ключ или нет?).
Мультимножества используются в ситуациях, когда нужно найти количество заданных элементов в большом наборе (сколько ключей?).
Задачи:
определить количество различающихся слов в тексте (set)
определить частоту появления различных слов в тексте (multiset)

Использование множеств и мультимножеств

Слайд 13

• map
Упорядоченный ассоциативный массив пар элементов, состоящих из ключа (типа Key)

• map Упорядоченный ассоциативный массив пар элементов, состоящих из ключа (типа Key)
и соответствующего ему значения (типа Т). Ключи должны быть уникальны. Обеспечивает быструю выборку элемента типа Т на основе заданного ключа.
• multimap
Множественный упорядоченный ассоциативный массив. Аналогичен map, но позволяет хранить дублированные ключи.

Компоненты STL – ассоциативные массивы

Слайд 14

Синтаксис определения map

template class Type,
class Traits=less,

Синтаксис определения map template class Type, class Traits=less , class Allocator=allocator >>
class Allocator=allocator< pair>>
class map

Параметры
Key тип ключа в множестве
Type тип элемента данных в множестве
Traits тип функционального объекта, который используется для сравнения ключей
(по умолчанию less)
Allocator тип аллокатора для пары ключ/значение.

Слайд 15

Пример использования map

Задача:
создать программу – телефонный справочник.
Данные в справочнике

Пример использования map Задача: создать программу – телефонный справочник. Данные в справочнике
должны хранится в виде пар «имя абонента» - «номер телефона». Программа должна обеспечивать быструю выборку телефонного номера по имени абонента.
Имя абонента и его номер может храниться в переменных типа string и long. Так как поиск будет вестись по имени, то имя в этой паре является ключем, а номер телефона – значением элемента. Используем контейнер map для хранения телефонного справочника.

Слайд 16

Пример 4 (map) – начало


#include
#include

Пример 4 (map) – начало #include #include #include using namespace std; int
#include
using namespace std;
int main()
{
map directory;
directory["Marina Semenova"] = 1234567;
directory["Vasiliy Zaitsev"] = 9876543;
directory["Andrey Petukhov"] = 3459876;
...

Слайд 17

... // поиск номеров телефонов
string name;
while (cin >> name)

... // поиск номеров телефонов string name; while (cin >> name) {
{
if(directory.find(name) !=
directory.end())
cout << «Телефон " << name << " - "
<< directory[name] << "\n";
else
cout << "Извините, в списке нет "
<< name << "\n";
return 0;
}

Пример 4 (map) - окончание

Имя файла: Библиотека-STL.-Отсортированные-ассоциативные-контейнеры.-(Лекция-16).pptx
Количество просмотров: 20
Количество скачиваний: 0