3.5.1. Пример: выявление повторяющихся слов
Присваивание необходимо, когда нам требуется записать в объект новое значение. Если подумать, то станет совершенно ясно, что присваивание является особенно полезным, когда приходится повторять операции несколько раз. Присваивание необходимо, когда требуется повторить операцию с новым значением. Рассмотрим небольшую программу, выявляющую повторяющиеся слова в предложении. Такие программы являются частью большинства инструментов для проверки грамматики.
int main()
{
string previous = " "; // переменная previous;
// инициализована "не словом"
string current; // текущее слово
while (cin>>current) { // считываем поток слов
if (previous == current) // проверяем, совпадает ли
// слово с предыдущим
cout << " повторяющееся слово: " << current << '\n';
previous = current;
}
}
Эту программу нельзя назвать очень полезной, поскольку она не способна указать, в каком именно месте стоит повторяющееся слово, но этого для нас пока достаточно. Рассмотрим эту программу строка за строкой.
string current; // текущее слово
Это строковая переменная, в которую мы сразу же считываем текущее (т.е. только что прочитанное) слово с помощью оператора
while (cin>>current)
while
, интересна сама по себе, поэтому мы еще вернемся к ней в разделе 4.4.2.1. Ключевое слово while
означает, что инструкция, стоящая следом за выражением cin>>current
, будет повторяться до тех пор, пока выполняется операция cin>>current
, а операция cin>>current
будет выполняться до тех пор, пока в стандартном потоке ввода есть символы.
Напомним, что для типа string
оператор считывает слова, отделенные друг от друга разделителями. Этот цикл завершается вводом символа конца ввода (как правило, называемым
Итак, мы должны считать текущее слово из потока ввода и сравнить его с предыдущим словом (уже хранящимся в памяти). Если они окажутся одинаковыми, мы сообщим об этом.
if (previous == current) // проверяем, совпадает ли слово
// с предыдущим
cout << " повторяющееся слово: " << current << '\n';
Теперь мы должны повторить описанную операцию. Для этого копируем значение переменной current
в переменную previous
.
previous = current;
Эта инструкция учитывает все возможные ситуации, кроме начальной. Что делать с первым словом, у которого нет предыдущего, с которым его следовало бы сравнивать? Эта проблема решается с помощью следующего определения переменной previous
:
string previous = " "; // переменная previous; инициализована
// "не словом"
Строка состоит из одного символа (пробела, который вводится путем нажатия клавиши пробела). Оператор ввода >>
пропускает разделители, поэтому мы не смогли бы считать этот символ из потока ввода. Следовательно, в ходе первой проверки while
сравнение
if (previous == current)
покажет, что значения переменных не совпадают (что и требовалось).
ПОПРОБУЙТЕ
Выполните эту программу самостоятельно, записывая промежуточные результаты на лист бумаги. Для проверки используйте фразу “The cat cat jamped”. Даже опытные программисты используют этот прием для визуализации относительно неочевидных действий в небольших фрагментах кода.
ПОПРОБУЙТЕ
Запустите программу для выявления повторяющихся слов. Проверьте предложение “She she laughed He He because what he did did not look very very good good”. Сколько раз повторяются слова в этом предложении? Почему? Что значит
3.6. Составные операторы присваивания