Стенли Липпман - Язык программирования C++. Пятое издание
- Название:Язык программирования C++. Пятое издание
- Автор:
- Жанр:
- Издательство:Издательский дом Вильямс
- Год:2014
- Город:Москва
- ISBN:978-5-8459-1839-0
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Стенли Липпман - Язык программирования C++. Пятое издание краткое содержание
Вы держите в руках новое издание популярного и исчерпывающего бестселлера по языку программирования С++, которое было полностью пересмотрено и обновлено под
. Оно поможет вам быстро изучить язык и использовать его весьма эффективными и передовыми способами. В соответствии с самыми передовыми и современными методиками изложения материала авторы демонстрируют использование базового языка и его стандартной библиотеки для разработки эффективного, читабельного и мощного кода.
С самого начала этой книги читатель знакомится со стандартной библиотекой С++, ее самыми популярными функциями и средствами, что позволяет сразу же приступить к написанию полезных программ, еще не овладев всеми нюансами языка. Большинство примеров из книги было пересмотрено так, чтобы использовать новые средства языка и продемонстрировать их наилучшие способы применения. Эта книга — не только проверенное руководство для новичков в С++, она содержит также авторитетное обсуждение базовых концепций и методик языка С++ и является ценным ресурсом для опытных программистов, особенно желающих побыстрей узнать об усовершенствованиях С++11.
Стенли Б. Липпман Жози Лажойе Барбара Э. Му • Узнайте, как использовать новые средства языка С++11 и стандартной библиотеки для быстрого создания надежных программ, а также ознакомьтесь с высокоуровневым программированием
• Учитесь на примерах, в которых показаны передовые стили программирования и методики проектирования
• Изучите принципы и узнайте почему язык С++11 работает именно так
• Воспользуйтесь множеством перекрестных ссылок, способных помочь вам объединить взаимосвязанные концепции и проникнуть в суть
• Ознакомьтесь с современными методиками обучения и извлеките пользу из упражнений, в которых подчеркиваются ключевые моменты, позволяющие избежать проблем
• Освойте лучшие методики программирования и закрепите на практике изученный материал
Исходный код примеров можно загрузить с веб-страницы книги на сайте издательства по адресу: http://www.williamspublishing.com
Язык программирования C++. Пятое издание - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
11.3.6. Карта преобразования слов
Завершим этот раздел программой, иллюстрирующей создание, поиск и перебор карты. Программа получает одну строку и преобразует ее в другую. Программе передаются два файла: первый содержит правила, используемые для преобразования текста во втором файле. Каждое правило состоит из слова, которое может встретиться во входном файле, и фразы, используемой вместо него. Идея в том, чтобы, встретив во вводе некое слово, заменить его соответствующей фразой. Второй файл содержит преобразуемый текст.
Вот содержимое файла преобразования слов.
brb be right back
k okay?
y why
r are
u you
pic picture
thk thanks!
l8r later
Подлежащий преобразованию текст таков:
where r u
y dont u send me a pic
k thk l8r
Программа должна создать следующий вывод:
where are you
why dont you send me a picture
okay? thanks! later
Решение подразумевает использование трех функций. Функция word_transform()будет осуществлять общую обработку. Потребуются два аргумента типа ifstream: первый будет связан с файлом преобразования слов, а второй — с текстовым файлом, который предстоит преобразовать. Функция buildMap()будет читать файл правил преобразования и создавать элемент карты для каждого слова и результата его преобразования. Функция transform()получит строку и, если она есть в карте, возвратит результат преобразования.
Давайте начнем с определения функции word_transform(). Важнейшие ее части — вызовы функций buildMap()и transform():
void word_transform(ifstream &map_file, ifstream &input) {
auto trans_map = buildMap(map_file); // хранит преобразования
string text; // содержит каждую строку из ввода
while (getline(input, text)) { // читать строку из ввода
istringstream stream(text); // читать каждое слово
string word;
bool firstword = true; // контролирует вывод пробела
while (stream >> word) {
if (firstword)
firstword = false;
else
cout << " "; // вывод пробела между словами
// transform() возвращает свой первый аргумент или
// результат преобразования
cout << transform(word, trans_map); // вывод результата
}
cout << endl; // обработка текущей строки ввода окончена
}
}
Функция начинается вызовом функции buildMap(), создающим карту преобразования слов. Результат сохраняется в карте trans_map. Остальная часть функции обрабатывает входной файл. Цикл whileиспользует функцию getline()для чтения входного файла по одной строке за раз. Построчно чтение осуществляется для того, чтобы строки вывода заканчивались там же, где и строки входного файла. Для получения слов каждой строки используется вложенный цикл while, использующий строковый поток istringstream(см. раздел 8.3) для обработки каждого слова текущей строки.
Внутренний цикл whileвыводит результат, используя логическую переменную firstword, чтобы решить, выводить ли пробел. Вызов функции transform()получает подлежащее выводу слово. Значение, возвращенное функцией transform(), будет либо исходным словом строки, либо соответствующим ему преобразованием из карты transmap.
Функция buildMap()читает переданный ей файл и создает карту преобразований.
map buildMap(ifstream &map_file) {
map trans_map; // хранит преобразования
string key; // слово для преобразования
string value; // фраза, используемая вместо него
// прочитать первое слово в ключ, а остальную часть строки в значение
while (map_file >> key && getline(map_file, value))
if (value.size() > 1) // проверить, есть ли преобразование
trans_map[key] = value.substr(1); // убрать предваряющий
// пробел
else
throw runtime_error("no rule for " + key);
return trans_map;
}
Каждая строка файла map_fileсоответствует правилу. Каждое правило — это слово, сопровождаемое фразой, способной содержать несколько слов. Для чтения слов, преобразуемых в ключи, используется оператор >>и функция getline()для чтения остальной части строки в значение. Поскольку функция getline()не отбрасывает предваряющие пробелы (см. раздел 3.2.2), необходимо убрать пробел между словом и соответствующим ему правилом. Прежде чем сохранить преобразование, осуществляется проверка наличия в нем хотя бы одного символа. Если это так, то происходит вызов функции substr()(см. раздел 9.5.1), позволяющий устранить пробел, отделяющий фразу преобразования от соответствующего ему слова, и сохранить эту подстроку в карте trans_map.
Обратите внимание на использование оператора индексирования при добавлении пары ключ-значение. При этом неявно игнорируется происходящее при повторении слова в файле преобразования. Если слово повторяется несколько раз, то в карте trans_mapокажется последняя соответствующая фраза. По завершении цикла whileкарта trans_mapсодержит все данные, необходимые для преобразования ввода.
Фактическое преобразование осуществляет функция transform(). Ее параметры — ссылки на преобразуемую строку и карту преобразования. Если переданная строка находится в карте, функция transform()возвращает соответствующую ей фразу преобразования. Если переданной строки в карте нет, функция transform()возвращает свой аргумент:
const string &
transform(const string &s, const map &m) {
// фактическая работа карты; это основная часть программы
auto map_it = m.find(s);
// если слово есть в карте преобразования
if (map it != m.cend())
return map_it->second; // использовать замену слова
else
return s; // в противном случае возвратить исходное слово
}
Код начинается с вызова функции find(), позволяющего определить, находится ли данная строка в карте. Если это так, то функция find()возвращает итератор на соответствующий элемент. В противном случае функция find()возвращает итератор на элемент после конца. Если элемент найден, обращение к значению итератора возвращает пару, содержащую ключ и значение этого элемента (см. раздел 11.3). Функция возвращает значение переменной-члена secondэтой пары, являющееся преобразованной фразой, используемой вместо строки s.
Упражнение 11.33. Реализуйте собственную версию программы преобразования слов.
Упражнение 11.34. Что будет, если в функции transform()вместо функции find()использовать оператор индексирования ?
Интервал:
Закладка: