Циклы. переход по метке. Примеры.
5.4. Циклы В цикле "с параметром n " задаются начальное значение параметра к, его конечное значение к и шаг ш - отличная от нуля величина, на которую изменяется значение параметра и после выполнения очередной итерации. В 1С шаг ш всегда принимается равным единице. Параметр п также называют переменной цикла, которая должна быть целочисленной. Параметры н и к являются в 1С числовыми выражениями и представляют соответственно нижнюю и верхнюю границы переменной цикла. Если параметр н (к) вычисляется с нецелым значением, то в качестве параметра используется целая часть результата. Параметр цикла часто называют его индексом, для обозначения которого в программах нередко употребляют имя ин или инд.
Графически цикл "с параметром" иллюстрирует рис. 2.6. Рис. 2.6. Цикл с параметром Цикл "с параметром" работает так (случай ш > 0): 1. Присвоить: п = н. 2. Если п <= к, то перейти к п.3, иначе завершить цикл. 3. Выполнить БОК. 4. Присвоить: п = п + ш и перейти к п.2 (повтор). Когда ш < 0, п.2выглядит так: Цикл Пока выполняется до тех пор, пока истинно некоторое ЛВ. Причем проверка истинности ЛВ выполняется перед началом очередной итерации. Цикл До отличается от цикла Пока тем, что проверка истинности ЛВ осуществляется после выполнения очередной итерации. Графическая интерпретация циклов Пока и До приведена на рис. 2.7.
Рис. 2.7. цикл Пока При работе с циклом Пока надо следить, чтобы ЛВ обязательно рано или поздно приняло значение ложь. Иначе произойдет зацикливание - "бесконечное" выполнение операторов цикла. Запись цикла Пока в 1С: пока ЛВ цикл БОК // Некоторые операторы конецЦикла; 1. Далее при ссылке на циклы будем использовать принятые в 1С имена операторов циклов - Для и Пока. 2. Циклы Для и Пока могут быть вложенными. То есть в теле цикла Для (Пока) могут быть другие циклы Для и/или Пока. Например, записав код вывода групп подряд следующих непериодических констант, сообщающий перед выводом группы ее номер. (Уточним: в примере группа - это подмножество подряд следующих непериодических констант, не имеющее периодических констант. То есть группы разделяются одной и более периодическими константами.) Перейти метка;
Этот оператор неприемлем для сторонников структурного программирования. Однако есть ситуации, кода он полезен, например для досрочного выхода из вложенного цикла. 50 Программирование «сверху в низ». Примеры Разработка алгоритмов и программ осуществляется, как правило, по принципу "сверху вниз". Суть такого подхода состоит в разбиении исходной задачи на ряд более простых задач - фрагментов - и последующей работе с ними. При разбиении задачи на фрагменты надо придерживаться следующей схемы: 1. Проанализировать задачу и выделить в ней фрагменты. 2. Отобразить процесс разбиения в виде блок-схемы или линейной схемы и пронумеровать в ней фрагменты. 3. Установить между выделенными фрагментами связи: для каждого фрагмента определить, какие данные он получает (входные данные) и какие данные возвращает (выходные данные). Связи между фрагментами называются интерфейсом. 4. Рассмотреть далее каждый фрагмент самостоятельно; разработать для него алгоритм и записать его либо в виде линейной схемы, либо в виде блок-схемы. При необходимости подвергнуть фрагмент разбиению на более мелкие фрагменты. Такое разбиение продолжать до тех пор, пока не будут получены фрагменты, программирование которых не составляет особых затруднений. 5. Оформить выделенные фрагменты в виде программных компонентов или БОК. При таком подходе программу можно рассматривать как совокупность фрагментов, которые, принимая некоторые данные, вырабатывают результат и передают его другому фрагменту и так вплоть до завершения вычислений. Составляемые для фрагментов линейные схемы алгоритмов (разд. 2.8) сопровождаются заголовком и описанием интерфейса, отражающим состав входных и выходных данных. В 1С для реализации фрагментов можно использовать программные компоненты: § основную программу модуля; § процедуры и функции модуля.
|