- •3. Введение в язык программирования паскаль
- •3.1. Краткая характеристика языка
- •Алфавит, лексемы, разделители
- •3.1.2. Структура программы
- •3.2. Средства кодирования вычислительных операций
- •3.2.1. Операция ввода
- •3.2.2. Операция присваивания
- •3.2.3. Операция вывода
- •3.3. Средства кодирования управляющих конструкций
- •3.3.1. Кодирование структуры «Ветвление»
- •3.3.2. Кодирование структуры «Цикл»
- •3.4. Кодирование алоритма в целом
- •Заключение
- •Вопросы для самоконтроля
3.1.2. Структура программы
Н
Program
< Имя_программы
>;
<Раздел указания
используемых модулей>
<Раздел деклараций>:
< Секция объявления
констант>
< Секция объявления
типов>
< Секция объявления
переменных>
< Секция объявления
процедур и функций>
begin
<Операторы,
описывающие алгоритм>
end.
Раздел указания используемых модулейпомещается в том случае, если в тексте программы используются константы, переменные, процедуры или функции, определенные в стандартных модулях Турбо-Паскаля или модулях, созданных пользователем.
Пример записи:
UsesCRT, Mylib; {Использовать модули CRT, Mylib }
Раздел деклараций(объявлений объектов программы) не является обязательным, однако без его использования можно написать только самые примитивные программы. Раздел состоит из нескольких секций, причем однотипные секции могут повторяться в разделе произвольное число раз. Порядок секций должен быть установлен в соответствии со следующим правилом:
Если в объявлении какого-либо элемента B (константы, типа, переменной, процедуры, функции) используется элемент А (константа, тип и т.п.), то элемент А должен быть описан перед элементом В.
Каждая секция раздела идентифицируется и начинается специальным ключевым словом, а элементы, объявляемые в ней, отделяются символом точка с запятой. Признаком окончания секции является ключевое слово следующей секции или ключевое слово begin, выполняющее функцию начала исполнимой части программы, содержащей операторы.
Приведем примеры записи отдельных секций.
Секция константиспользуется для того, чтобы присвоить идентификаторы (имена) константам. В этом случае далее в тексте программы можно вместо констант использовать эти имена.
П
Const
nmax
= 10;
name = ’ file.dat’;
Секция типовпоявляется тогда, когда программисту недостаточно так называемых стандартных типов, предоставляемых системой Турбо Паскаль по умолчанию. Применительно к данным тип определяет диапазон или перечень разрешенных значений, а также перечень допустимых операций над ними.
К стандартным типам относятся:
целые типы (integer, byte, word и другие);
вещественные типы (real, double и другие);
булевский тип (boolean);
символьный тип (char);
строковый тип (string);
и ряд других.
Б
and
-
конъюнкция (логическое умножение)
or
- дизъюнкция (логическое сложение)
xor
– отрицание
равнозначности
not
- отрицание
Переменные и константы символьного типамогут принимать значения из множества символов таблицы ASCII (американский стандартный код обмена информацией).
Переменные и константы строкового типа представляют собой цепочки символов из множества символов таблицы ASCII, рассматриваемые как единое целое. В то же время с позиций обработки строку можно рассматривать и как массив символов ASCII.
В
Type Season
= (Spring, Summer, Autumn, Winter); DayOfMonth
= 1 .. 31;
Здесь
Season– перечислимый тип (значения констант этого типа задаются перечислением в круглых скобках), а допустимые операции – операции сравнения и присваивания;
DayOfMonth – интервальный тип (константы этого типа – все целочисленные значения в интервале от 1 до 31), а допустимые операции – те же, что и для целых чисел, с тем только ограничением, что результаты арифметических операций над ними не должны выходить за границы интервала.
Выше были рассмотрены только так называемые скалярные типы – это типы, в которых любая переменная может одновременно принять значение только одной константы.
В то же время в языке определены и так называемые структурныетипы
массив (array);
множество (set);
запись (record);
файл (file);
объектный тип (object).
Структурные типыслужат для объявления и использования переменных, которые могут одновременно хранить много значений. В качестве примера приведем объявление типа массив:
З
Type
Arr10
= array [1 .. 10] of Integer;
С
Var
<Имя
переменной>
: <имя типа>;
<Список
имен
переменных>
: <имя типа>;
<Имя
массива>
: array [<граничная
пара>]
of <имя типа элемента
массива>;
П
Var
x
: real; i,
j : integer;
st
: array[1..25]
of
char;
a,
b : array[1..100] of real; {Объявление
двух массивов}
Объявление процедуры и функции имеет такую же структуру, что и программа, с небольшими отличиями, и будет рассмотрено позже.
Раздел операторовсодержит запись алгоритма в виде последовательности операторов Паскаля. В данном разделе мы рассмотрим только те операторы, которые необходимы для кодирования базовых операций и управляющих структур, использованных для записи алгоритма на псевдокоде. Прочие операторы можно изучить позже, когда будут приобретены навыки разработки программ и когда в этом возникнет необходимость.
Оператор – это предложение на языке Паскаль, которое идентифицируется одним или несколькими ключевыми словами, и признаком конца которого является символ «точка с запятой». Операторы имеют различающиеся правила построения (синтаксис), и знакомство с ними лучше всего обеспечить при рассмотрении каждого в отдельности.
