Читаем С++ для "чайников" . полностью

        /* Имя студента ( а также прочие данные ) */

        string name ;

    } ;

    int main( int argc , char* pArgs[ ] )

    {

        setlocale ( LC_ALL , ".1251" ) ; /* печать кириллицы */

        /* Добавляем несколько студентов в коллекцию */

        Student* pS ;

        pS = new Student( "Алла" , 3456 ) ;

        Pair* ptr = new Pair( pS -> getKey( ) , pS ) ;

        students.insert( *ptr ) ;

        /* Ассоциативный массив перегружает оператор индексирования для создания пары и вставки её в массив */

        students[ 1234 ] = new Student( "Лариса" ,

                                           1234 ) ;

        students[ 5678 ] = new Student( "Марианна" ,

                                           5678 ) ;

        /* Проход по списку студентов. Ассоциативный массив всегда хранит элементы упорядоченными по ключу */

        cout << "Отсортированный список студентов:" << endl ;

        MapIterator iter = students.begin( ) ;

        while ( iter != students.end( ) )

        {

            Pair p = *iter ;

            Student* s = p.second ;

            cout << s -> display( ) << endl ;

            iter++ ;

        } 

_________________

325 стр. Глава 28. Стандартная библиотека шаблонов

        /* Операторы инкремента и декремента могут использоваться для поиска предыдущего и последующего элемента */

        cout << "\nИщем студента 3456" << endl ;

        MapIterator p = students.find( 3456 ) ;

        cout << "Найден: " << p -> second -> display( ) << endl ;

        MapIterator p1 = p ;

        MapIterator prior = --p1 ;

        cout << "Предшественник = "

              << prior -> second -> display( ) << endl ;

        MapIterator p2 = p ;

        MapIterator successor = ++p2 ;

        cout << "Следующий = "

              << successor -> second -> display( ) << endl ;

        /* Функция find( ) возвращает итератор end( ), если искомый элемент не найден; operator[ ] возвращает NULL */

        if ( students.find( 0123 ) == students.end( ) )

        {

            cout << "Вызов students.find( 0123 ) возвратил\n"

                  << "students.end( ), т.к. студента 0123 нет"

                  << endl ;

        }

        /* Вывод с использованием индекса */

            cout << "Проверка индекса: students[ 3456 ] = "

                  << students[ 3456 ] -> display( ) << endl ;

        if ( students[ 0123 ] == NULL )

        {

            cout << "students[ 0123 ] возвращает NULL"

                  << endl ;

        }

        /* Пауза для того, чтобы посмотреть на результат работы программы */

        system( "PAUSE" ) ; return 0 ;

    } 

Ключевым моментом программы являются три оператора typedef. Контейнер map содержит множество объектов Pair, каждый из которых содержит по два элемента. Первый элемент — ключ ( в нашем случае — идентификатор студента ), а второй — сам объект Student. В аргументы шаблона Map добавлен класс SC, который содержит единственный метод, сравнивающий два ключа ( это немного сложнее, чем глобальная функция, использованная в контейнере list, но эффект абсолютно тот же ).

Программа начинает работу с создания трёх объектов Pair и вносит их в список. Затем проход по контейнеру показывает, что он хранит элементы упорядоченными по ключу, так что вызов метода sort( ) нам не нужен.

Во второй части программы выполняется поиск с использованием метода find( ), а также выборка предыдущего и последующего элементов контейнера при помощи операторов инкремента и декремента.

_________________

326 стр. Часть 5. Полезные особенности

Вывод программы выглядит следующим образом:

    Отсортированный список студентов:

    1234 — Лариса

    3456 — Алла

    5678 — Марианна

    Ищем студента 3456

Перейти на страницу:

Все книги серии Для чайников

Похожие книги

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных