Язык блок-схем. Использование циклов с предусловием | Команда цикла

Планирование уроков на учебный год (34 часа, 1 урок в неделю)


Уроки 16 - 20
Язык блок-схем
Использование циклов с предусловием
(§ 6. Циклические алгоритмы)
Разработка циклических алгоритмов




Содержание урока

Команда цикла

Цикл в процедуре

Блок-схемы алгоритмов

Цикл с предусловием

Вопросы и задания

Компьютерный практикум ЦОР. Циклические алгоритмы


Команда цикла







Обсудим решение следующей задачи.

imageЗадача 3. Исходное положение: ГРИС — у левого края поля, направление — на восток. Требуется нарисовать горизонтальную линию через весь экран.

Задачу можно решить, написав 15 раз команду шаг (если поперек поля рисунка 15 шагов). Но есть и более короткий вариант программы. Вот он:

пока впереди не край повторять

нц

шаг

кц

Здесь использована команда, которая называется циклом. Формат команды цикла следующий:

пока <условие> повторять

нц

<тело цикла>

кц

Служебное слово нц обозначает начало цикла, кц — конец цикла. Это первая команда из СКИ, которая реализует обратную связь между графическим исполнителем и управляющим им компьютером. Она заключается в том, что проверяется, не вышел ли ГРИС на край поля, не грозит ли ему следующий шаг или прыжок в этом направлении аварией. Проверяемые условия звучат так: «впереди край?» или «впереди не край?». На что машина получает от исполнителя ответ «да» или «нет».

В приведенном примере проверяется условие «впереди не край?». Если «да», то делается шаг (т. е. выполняется <тело цикла>). Затем происходит возврат на проверку условия, и всё повторяется. Если проверка условия дает отрицательный результат (т. е. впереди край), то выполнение цикла завершается и исполняется следующая после цикла команда программы.

При программировании цикла важно думать о том, чтобы цикл был конечным. Цикл, записанный выше, конечный. Двигаясь в одном направлении, исполнитель обязательно достигнет края, и на этом выполнение цикла закончится.

imageСитуация, при которой выполнение цикла никогда не заканчивается, называется зацикливанием. Пусть ГРИС находится в середине поля. Исполнение следующего цикла:

пока впереди не край повторять

нц

шаг

поворот

кц

никогда не закончится. ГРИС будет бесконечно рисовать квадратик, так как проверка условия «впереди не край?» всегда будет давать положительный ответ.




Следующая страница Цикл в процедуре







Наверх