Основные служебные слова
алг (алгоритм) |
сим (символьный) |
дано |
для |
да |
| ||||
арг (аргумент) |
лит (литерный) |
надо |
от |
нет | |||||
рез (результат) |
лог (логический) |
если |
до |
при | |||||
нач (начало) |
таб(таблица) |
то |
знач |
выбор | |||||
кон (конец) |
нц (начало цикла) |
иначе |
и |
ввод | |||||
цел (целый) |
кц (конец цикла) |
все |
или |
вывод | |||||
вещ (вещественный) |
длин (длина) |
пока |
не |
утв |
Общий вид алгоритма: алг название алгоритма (аргументы и результаты) дано условия применимости алгоритма надо цель выполнения алгоритма нач описание промежуточных величин | последовательность команд (тело алгоритма) кон |
Часть алгоритма от слова алг
до слова нач называется заголовком, а часть, заключенная между словами нач и кон
— телом алгоритма.
В предложении алг
после названия алгоритма в круглых скобках указываются характеристики (арг, рез) и тип значения (цел, вещ, сим, лит или лог) всех входных
(аргументы) и выходных (результаты) переменных. При описании массивов (таблиц) используется служебное слово таб, дополненное граничными парами по каждому индексу элементов массива.
Примеры предложений алг:
алг Объем и площадь цилиндра ( арг вещ R, H, рез вещ V, S )
алг Корни КвУр ( арг вещ а, b, c, рез вещ x1, x2, рез лит t )
алг
Исключить элемент ( арг цел N, арг рез вещ таб А[1:N] )
алг
Диагональ ( арг цел N, арг цел таб A[1:N, 1:N], рез лит Otvet )
Предложения дано и надо
не обязательны. В них рекомендуется записывать утверждения, описывающие состояние среды исполнителя алгоритма, например:
1. алг Замена (арг лит Str1, Str2, арг рез лит Text)2. дано | длины подстрок Str1 и Str2 совпадают3. надо | всюду в строке Text подстрока Str1 заменена на Str2
5. алг Число максимумов (арг цел N, арг вещ таб A[1:N], рез цел K)6. дано | N>07. надо | К — число максимальных элементов в таблице А
9. алг Сопротивление (арг вещ R1, R2, арг цел N, рез вещ R)10. дано | N>5, R1>0, R2>011. надо | R — сопротивление схемы
Здесь в предложениях дано
и надо после знака "|" записаны комментарии. Комментарии можно помещать в конце любой строки. Они не обрабатываются транслятором, но существенно облегчают понимание алгоритма.