| |||||||||||||||||||||||||||||||||||||||
|
2.4. Операторы повтора (цикла).При решении многих задач некоторую последовательность действий приходится выполнять несколько раз. Например, чтобы найти фамилию ученика в списке, надо проверить первую фамилию списка, затем вторую, третью и т.д. до тех пор, пока не будет найдена нужная или не будет достигнут конец списка. Такие повторяющиеся действия называются циклами и реализуются в программе с использованием инструкций циклов. В Турбо Паскале различают три вида операторов организации циклов:
2.4.1. Оператор цикла while. Цикл с предусловием характерен тем, что перед
выполнением цикла всегда необходимо проверить условие. Если условие истинно, то
цикл продолжается, иначе - цикл заканчивается. Оператор цикла while действует следующим образом. Предварительно проверяется значение логического выражения. Пока оно истинно, выполняется оператор циклической части (после do). Как только значение логического выражения становится ложным, происходит выход из цикла. Если с самого начала значение логического выражения
ложно, то оператор циклической части не выполняется ни разу. Если логическое
выражение никогда не принимает значение False (ложно), то цикл будет выполняться
бесконечно долго. В ряде случаев цикл изначально предполагается как
бесконечный. Тогда в условии записывается константа True или очевидный факт,
который в любой ситуации возвращает значение True. Второй вариант менее
предпочтителен. 2.4.2. Оператор цикла repeat.Оператор повтора repeat состоит из заголовка (repeat), тела цикла и условия окончания (until). Цикл с постусловием характерен тем, что вначале обязательно выполняются хотя бы один раз команды, составляющие тело цикла. После выполнения операторов циклической части
проверяется условие. Если условие ложно, то вновь выполняются операторы
циклической части. Если условие истинно, то цикл заканчивается. <Логическое_выражение> (условие) - выражение булевского типа. При написании условия допустимы булевские операции и операции отношения. Операторы, заключенные между словами repeat и until, являются телом цикла. Оператор цикла repeat действует следующим образом:
Пример: В приведенном фрагменте программы описано вычисление A**7 с использованием цикла repeat: .............. I := 1; P := 1; repeat P := P * A; Inc(I) until I > 7; .............. Пример: Программа нахождения простых чисел. Как известно, число называется простым, если оно делится только на единицу и себя. Проверить, является ли число N простым, можно делением на 2, на 3 и т.д. до N и проверкой остатка после каждого деления. Если остаток равен 0, то следовательно найдено число, на которое N делится без остатка. Сравнив N и полученное таким образом число, можно определить, является ли N простым. program ProstoeChislo; uses CRT; var N, d, r : integer; Begin ClrScr; Write('Введите целое число: '); ReadLn(N); d := 2; { сначала делим на 2 } repeat r := N mod d; { вычисление остатка от деления } { если N не разделилось нацело на d } if r <> 0 then d := d + 1; until r = 0; { выполнять, пока не нашли число, на которое делится N } { если число N равно d, то ... } if d = N then WriteLn(N, '- простое число') else WriteLn(N, '- не является простым числом'); repeat until KeyPressed End. Примечание: Оператор repeat until KeyPressed (исполняется "пустой" цикл до тех пор, пока не будет нажата любая клавиша) служит для задержки результата выполнения программы до нажатия на любую клавишу. Для преждевременного выхода из цикла можно
использовать оператор goto (хотя в большинстве случаев можно обойтись и без
него, присвоив параметру цикла выходящее за допустимый диапазон
значение): 2.4.3. Оператор цикла for. Цикл с параметром характерен тем, что количество
исполняемых циклов определено в заголовке цикла при записи оператора
for. В качестве переменной I может использовать только простую переменную, а в качестве N1, N2 могут использоваться выражения (за исключением вещественного типа real). Параметры I, N1, N2 должны быть одного и того же
скалярного типа, но не real (т.е. целого, символьного, ограниченного типа или
типа "перечисление"). Переменная цикла I принимает последовательные значения
данного типа от N1 до N2. Если I, N1, N2 - целого типа, то в этом случае шаг
изменения переменной цикла всегда равен +1. Пример цикла, когда параметр принимает значения символьного типа: for I = 'A' to 'W' do Write(' ', I). В примере осуществляется печать букв латинского алфавита от A до W. Пример цикла, когда параметр принимает значения
типа "перечисление". Если необходимо записать цикл по убывающим
значениям параметра I от N1 до N2, то используется следующий
оператор:
uses CRT; var m, k : integer; V : real; Begin ClrScr; m := 8; V := 1.0; for k := 1 to m do V := V * Sqrt(Exp(k / 2 * Ln(m))) / (2 * (m - 1)); Write('V=', V:5:8) repeat until KeyPressed End. Для выхода из цикла до момента достижения
параметром цикла конечного значения можно воспользоваться оператором
goto: Однако с точки зрения структурного программирования такой путь не является правильным. В связи с этим во всех случаях, где возможен преждевременный выход из цикла, следует применять описанные выше операторы while и repeat. В теле оператора for могут находиться другие
операторы for. Это позволяет строить циклы, содержащие внутренние циклы. Такие
внутренние циклы называются вложенными, например: При Е=0.001 значение Pi=3.14358866. Просуммировано 502 члена ряда. |
| |||||||||||||||||||||||||||||||||||||
| |||||||||||||||||||||||||||||||||||||||
© Copyright(c) 2004 Amro Group. All rights reserved |
|