Циклы с условием (неопределенные циклы)

Циклы с условием используются в тех случаях, когда повторяющиеся действия нужно выполнять только при определенных условиях. Количество итераций не определено и в общем случае может быть равно нулю (в частности, для циклов с предусловием). VBA предлагает разработчикам несколько управляющих структур для организации циклов с условием:

· Четыре вида циклов Do..Loop, которые различаются типом проверяемого условия и временем выполнения этой проверки.

· Непрерываемый цикл While … Wend.

Цикл Do While … Loop - типичный цикл с предусловием. Условие проверяется до того, как выполняется тело цикла. Цикл продолжает свою работу, пока это <условие> выполняется (т.е. имеет значение True). Так как проверка выполняется в начале, то тело цикла может ни разу не выполниться. Формат цикла Do While … Loop:

          Do While <условие>                          <блок операторов>          Loop

Листинг 10. Цикл Do While … Loop

' ЗАДАЧА: Составить программу, которая предусматривает ввод пользователем ' произвольной последовательности чисел. Ввод должен быть прекращен ' только после того, как сумма введенных нечетных чисел превысит 100. Sub sample8()          Dim OddSum As Integer ‘сумманечетныхчисел          Dim OddStr As String ‘строка с нечетными числами                     Dim Num ‘для приема вводимых чисел           OddStr = "" ‘инициализация выходной строки           OddSum = 0 ‘инициализация суммы OddSum                     Do While OddSum < 100 ‘начало цикла                           Num = InputBox("Введите число: ")                           If (Num Mod 2) <> 0 Then ‘проверка на четность                                          OddSum = OddSum + Num ‘накопление суммы нечетных чисел                                          OddStr = OddStr & Num & " "                           End If           Loop           'вывод строки с нечетными числами           MsgBox prompt:="Нечетные числа: " & OddStr End Sub

Оператор Do … Loop While предназначен для организации цикла с постусловием. Условие проверяется после того, как тело цикла, будет выполнено хотя бы один раз. Цикл продолжает свою работу, пока <условие> остается истинным. Формат цикла Do … Loop While:

Do <блок операторов> Loop While<условие>

Листинг 11. Цикл с постусловием

' ЗАДАЧА: Составить программу игры "Угадай число". Программа должна случайным' образом генерировать число в диапазоне от 1 до 1000, пользователь должен ' угадать это число. Программа на каждое вводимое число выводит подсказку ' "больше" или "меньше". Sub sample8() Randomize Timer ' инициализация генератора случайных чисел           Dim msg As String ' строкасообщения          Dim SecretNumber As Long, UserNumber As Variant Begin: SecretNumber = Round(Rnd * 1000) ' число, сгенерированное компьютером           UserNumber = Empty ' число, вводимое пользователем           Do ' игровойпроцесс                          Select Case True                                          Case IsEmpty(UserNumber): msg = "Введитечисло"                                          Case UserNumber > SecretNumber: msg = "Слишкоммного!"                                          Case UserNumber < SecretNumber: msg = "Слишкоммало!"                           End Select                           UserNumber = InputBox(prompt:=msg, Title:="Угадайчисло")           Loop While UserNumber <> SecretNumber           ' проверка          IfMsgBox("Игратьеще? ", vbYesNo + vbQuestion, "Выугадали!") = vbYes Then                           GoTo Begin           End If End Sub

Циклы Do Until … Loop и Do … Loop Until являются инверсиями ранее рассмотренных циклов с условием. В общем случае они работают аналогично, за исключением того, что тело цикла выполняется при ложном условии (т.е. <условие>=False). Формат цикла Do Until … Loop:

Do Until <условие><блок операторов> Loop

ФорматциклаDo … LoopUntil:

Do           <блок операторов>Loop Until<условие>

Практическое задание: Перепишите программы из листингов 10 и 11 с использованием инвертированных операторов цикла.

Цикл While … Wend также относится к циклам с условием. Данный оператор полностью соответствует структуре Do While … Loop. Формат цикла While … Wend:

While <условие>          <блок операторов>Wend

Отличительной особенностью этого оператора является невозможность принудительного завершения (прерывания) тела цикла (оператор Exit Do не работает в цикле While … Wend).

Прерывание цикла

Для досрочного завершения итерации и выхода из цикла применяется оператор Exit. Этот оператор применим в любой циклической структуре, кроме While ... Wend. Общий синтаксис использования Exit для прерывания цикла таков:

<начало_цикла>          [<блок операторов1>]           Exit (For | Do)           [<блок операторов2>]           [Exit (For | Do)]           ... <конец_цикла>

При выполнении оператора Exit цикл прерывается, и управление передается оператору, следующему за оператором <конец_цикла>. В теле цикла может присутствовать несколько операторов Exit.

Листинг 12. Принудительный выход из цикла

Sub sample9()          For i = 1 To 10000000                           If i = 10 Then Exit For ' выход из цикла, когда счетчик достигнет 10           NextEndSub

 

Литература

1. Таганов Л. С., Пимонов А. Г. Информатика: [Электронныйресурс]: учеб.пособие для студентов техн. направлений испециальностей вузов/ Л. С. Таганов, А. Г. Пимонов; ГУ КузГТУ. – Кемерово, 2010. – 330 с.

2. Информатика. Базовый курс: учеб. пособие для студентов втузов/ под ред. С. В. Симоновича. - 3-е изд. - СПб.: Питер, 2012. - 640 с.

3. Таганов, Л. С. Конспекты лекций по курсу«ИНФОРМАТИКА»: [Электронный ресурс]: для студентов всех форм обученияспециальности130400.65 «Горное дело» / Л. С. Таганов; КузГТУ. – Кемерово, 2013. – 290 с.


Дата добавления: 2018-05-30; просмотров: 326; Мы поможем в написании вашей работы!

Поделиться с друзьями:




Мы поможем в написании ваших работ!