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

Как сортирует функция sort( )

Я должен разъяснить один интересный момент — откуда метод sort( ) знает, какой из двух элементов списка "больше"? Другими словами, как определяется порядок сортировки? Для ряда типов С++ определяет порядок сортировки самостоятельно. Так, например, С++ не надо пояснять, какой из двух int больше. Кроме того, STL сортирует коллекцию строк по тем же правилам, что используются в словаре.

Таким образом, программе, сортирующей имена в списке, не надо было ничего пояснять, поскольку С++ известно, как сортировать объекты типа string. Однако С++ не знает, какой из объектов student больше. Для этой цели служит глобальная функция ::operator<( Student&, Student& ). Метод sort( ) использует эту функцию для определения корректного порядка сортировки. В качестве эксперимента измените смысл оператора operator<( ) на обратный:

        return s1.ssID > s2.ssID ;

При этом вы должны получить тот же список, что и ранее, но выведенный в обратном порядке:

    25 — Шапран Павел

    20 — Чистяков Александр

    15 — Снежко Ирина

    10 — Семенякин Сергей

    5 — Редчук Александр

    Press any key to continue...

_________________

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

<p id="chapter28.4"><strong>►Использование контейнера <emphasis>map</emphasis>...324</strong></p>

Ассоциативный массив map представляет собой ещё один класс-контейнер. Имеется множество ассоциативных массивов, но все они обладают одним общим свойством — обеспечивают быстрое сохранение и выборку в соответствии с некоторым ключом или индексом. Приведённая ниже программа демонстрирует этот принцип на практике.

Например, в институте студенты могут быть зарегистрированы при помощи уникальных идентификационных номеров. Этот идентификационный номер используется во всех случаях студенческой жизни: для получения информации о студенте, при выдаче книг в библиотеке, записи в ведомость об оценках. Очень важно, чтобы любая программа могла получить информацию о студенте по его номеру быстро и эффективно.

Следующая программа демонстрирует использование ассоциативного массива студентов с идентификатором в качестве ключа.

    /* STLMap — использование ассоциативного массива */

    /*        для коллекции студентов, упорядоченной */

    /*              по их идентификаторам */

    #include

    #include

    #include

    #include

    #include

    #include

    using namespace std ;

    /* SC — Функция сравнения студентов, */

    /*      определяющая порядок их сортировки */

    struct SC

    {

        bool operator( )( const int id1 , const int id2 ) const

        {

            return id1 < id2 ;

        }

    } ;

    /* Ассоциативный массив в действительности содержит пары, первый элемент которых является ключом, а второй — данными ( в нашем случае — классом Student ) */

    class Student ;

    typedef Student* SP ;

    typedef pair< const int , Student* > Pair ;

    typedef map< int , SP , SC > Map ;

    typedef map< int , SP , SC >::iterator MapIterator ;

    /* Коллекция студентов */

    Map students ;

_________________

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

    /* Student — определяет важные свойства студентов, в первую очередь — ключ, используемый для выборки информации о студенте */

    class Student

    {

      public :

        Student( char* pszName , int id )

                : studentIDKey( id ) , name( pszName ) { }

        /* getKey — ключ, используемый в качестве индекса в ассоциативном массиве */

        const int getKey( ) { return studentIDKey ; }

        /* display — вывод информации на экран */

        string display( )

        {

            ostringstream out ;

            out << studentIDKey << " — " << name ;

            return out.str( ) ;

        }

      protected :

        /* Ключевое поле — идентификатор студента */

        const int studentIDKey ;

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

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

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

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

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

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

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

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

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

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