Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Шпоры по ТП.doc
Скачиваний:
39
Добавлен:
11.03.2015
Размер:
655.36 Кб
Скачать

Операции сравнения:

Матем-я запись

В паскале

=

A=b

не равно

A<>b

>

A>=b

<

A<=b

>

A>b

<

A<b

  1. NOT

    a

    not a

    False

    True

    True

    False

  2. AND & OR

a

b

a and b

a or b

True

True

True

True

False

True

False

True

True

False

False

True

False

False

False

False

В порядке убывания приоритета:

Логические; Арифметические; Сравнения.

Вопрос №11

Простые операторы языка ТР. Оператор присваивания. Преобразование типов.

К простым операторам относят: присванивания, вв/вывода.

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

Приведем некоторые примеры операторов присваивания:

X := Y + Z;
Done := (I >= 1) and (I < 100);
Huel := [blue, Succ(C)];

I := Sqr(J) - I * K;

Вопрос №12

Операторы ввода, вывода. Формат вывода данных.

Рассмотрим организацию ввода и вывода данных с терминального устройства. Терминальное устройство – это устройство, с которым работает пользователь, обычно это экран (дисплей) и клавиатура.

Для ввода и вывода данных используются стандартные процедуры ввода и вывода Read и Write, оперирующие стандартными последовательными файлами INPUT и OUTPUT.

Эти файлы разбиваются на строки переменной длины, отделяемые друг от друга признаком конца строки. Конец строки задается нажатием клавиши ENTER.

Для ввода исходных данных используются операторы процедур ввода:

Read(A1,A2,...AK);ReadLn(A1,A2,...AK);ReadLn;

1-й реализует чтение К значений исходных данных и присваивание этих значений переменным А1, А2, ..., АК. 2-й оператор реализует чтение К значений исходных данных, пропуск остальных значений до начала следующей строки, присваивание считанных значений переменным А1, А2, ..., АК. 3-й оператор реализует пропуск строки исходных данных.

При вводе исходных данных происходит преобразование из внешней формы представления во внутреннюю, определяемую типом переменных. Переменные, образующие список ввода, могут принадлежать либо к целому, либо к действительному, либо к символьному типам. Чтение исходных данных логического типа в языке Паскаль недопустимо.

Операторы ввода при чтении значений переменных целого и действительного типа пропускают пробелы, предшествующие числу. В то же время эти операторы не пропускают пробелов, предшествующих значениям символьных переменных, так как пробелы являются равноправными символами строк. 

Значения исходных данных могут отделяться друг от друга пробелами и нажатием клавиш табуляции и Enter.

Для вывода результатов работы программы на экран используются операторы:

Write(A1,A2,...AK);WriteLn(A1,A2,...AK);WriteLn;

1-й из этих операторов реализует вывод значений переменных А1, А2,..., АК в строку экрана. 2-й оператор реализует вывод значений переменных А1, А2, ..., АК и переход к началу следующей строки. 3-й оператор реализует пропуск строки и переход к началу следующей строки.

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

Вывод каждого значения в строку экрана происходит в соответствии с шириной поля вывода, определяемой конкретной реализацией языка.

Форматный вывод:

1. Целый( в Турбо Паскале для переменной целого типа отводится столько позиций,сколько необходимо): write(5:4)-‘ 5’. В одной строке 80 символов(при выводе на экран).

2. Вещественный

А) формат не указан.

Под переменные вещественного типа отводится 17 позиций.

- 2 .E 0 2

б)Формат указан одним целым:

x:=-216,86

write(x:7) <8

- 2 . 7 E +0 2

В) Формат задан 2 целыми:

x:=-216,86

write(x:4:1) 4-общее число позиций, 1-под дробную часть.

Вопрос №13

Логический тип данных. Описание и операции над данными логического типа. Логические выражения.

Логический тип (Boolean) определяет те данные, которые могут принимать логические значения TRUE и FALSE.

К булевским операндам применимы следующие логические операции:

not   and   or   xor.

Логический тип определен таким образом, что FALSE < TRUE. Это позволяет применять к булевским операндам все операции отношения.

В Турбо Паскаль введены еще разновидности логического типа: ByteBool, WordBool и LongBool, которые занимают в памяти ЭВМ один, два и четыре байта соответственно.

Вопрос №14

Символьный тип данных. Стандартные функции с символьными значениями и аргументами.

Символьный тип (Char) определяет упорядоченную совокупность символов, допустимых в данной ЭВМ. Значение символьной переменной или константы – это один символ из допустимого набора.

Символьная константа может записываться в тексте программы тремя способами:

– как один символ, заключенный в апострофы, например:

'A' 'a' 'Ю' 'ю';

– с помощью конструкции вида #K, где K – код соответствующего символа, при этом значение K должно находиться в пределах 0…255;

– с помощью конструкции вида ^C, где C – код соответствующего управляющего символа, при этом значение C должно быть на 64 больше кода управляющего символа.

К величинам символьного типа применимы все операции отношения.

Для величин символьного типа определены две функции преобразования

Ord(C),   Chr(K).

Первая функция определяет порядковый номер символа С в наборе символов, вторая определяет по порядковому номеру К символ, стоящий на К-м месте в наборе символов. Порядковый номер имеет целый тип.

К аргументам символьного типа применяются функции, которые определяют предыдущий и последующий символы:

Pred(C), Succ(C), Pred('F') = 'E', Succ('Y') = 'Z'.

При отсутствии предыдущего или последующего символов значение соответствующих функций не определено.

Вопрос №15

Простые типы, определяемые пользователем. Интервальный тип, перечисляемый тип.

Интервальный:Отрезок любого порядкового типа может быть определен как интервальный или ограниченный тип. Отрезок задается диапазоном от минимального до максимального значения констант, разделенных двумя точками. В качестве констант могут быть использованы константы, принадлежащие к целому, символьному, логическому или перечисляемому типам. Скалярный тип, на котором строится отрезок, называется базовым типом.

Минимальное и максимальное значения констант называются нижней и верхней границами отрезка, определяющего интервальный тип. Нижняя граница должна быть меньше верхней. Например,

0..99
-128..127
RED..VIOLET

Над переменными, относящимися к интервальному типу, могут выполняться все операции и применяться все стандартные функции, которые допустимы для соответствующего базового типа.

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

Перечисляемый:Перечисляемый тип представляет собой ограниченную упорядоченную последовательность скалярных констант, составляющих данный тип. Значение каждой константы задается ее именем. Имена отдельных констант отделяются друг от друга запятыми, а вся совокупность констант, составляющих данный перечисляемый тип, заключается в круглые скобки.

Программист объединяет в одну группу в соответствии с каким-либо признаком всю совокупность значений, составляющих перечисляемый тип.

Например, перечисляемый тип Rainbow(РАДУГА) объединяет скалярные значения RED, ORANGE, YELLOW, GREEN, LIGHT_BLUE, BLUE, VIOLET.

Перечисляемый тип описывается в разделе описания типов, который начинается со служебного слова type, например:

type
Rainbow = (RED, ORANGE, YELLOW, GREEN, LIGHT_BLUE, BLUE, VIOLET);

Каждое значение является константой своего типа и может принадлежать только одному из перечисляемых типов, заданных в программе.

Описание переменных, принадлежащих к скалярным типам, которые объявлены в разделе описания типов, производится с помощью имен типов. Например:

type Traffic_Light= (RED, YELLOW, GREEN);
var Section: Traffic_Light;

Это означает, что переменная Section может принимать значения RED, YELLOW или GREEN.

Переменные перечисляемого типа могут быть описаны в разделе описания переменных, например:

var Section: (RED, YELLOW, GREEN);

При этом имена типов отсутствуют, а переменные определяются совокупностью значений, составляющих данный перечисляемый тип.

К переменным перечисляемого типа может быть применим оператор присваивания:

Section: = YELLOW;

Упорядоченная последовательность значений, составляющих перечисляемый тип, автоматически нумеруется, начиная с нуля и далее через единицу. Отсюда следует, что к перечисляемым переменным и константам могут быть применены операции отношения и стандартные функции Pred, Succ, Ord.

Переменные и константы перечисляемого типа не могут быть элементами списка ввода или вывода.

Вопрос №16

Составной оператор. Оператор условного перехода.

Оператор перехода: Обычно операторы в программе выполняются в том порядке, в каком они записаны. Оператор перехода прерывает естественный порядок выполнения программы и указывает, что дальнейшее выполнение должно продолжаться, начиная с оператора, помеченного меткой, указанной в операторе перехода. Примеры записи оператора перехода:

goto 218;  goto l1;

При использовании оператора перехода должны соблюдаться следующие правила:

1. Метка, которая указывается в операторе перехода, должна находиться в том же блоке или модуле, что и сам оператор перехода. Другими словами, не допускаются переходы из процедуры или функции или внутрь нее.

2. Переход извне внутрь структурного оператора (то есть переход на более глубокий уровень вложенности) может вызвать непредсказуемые эффекты, хотя компилятор не выдает сообщения об ошибке. Например, вы не должны переходить в тело цикла for.

Хорошая практика программирования требует минимального использования переходов.

Составной оператор:В некоторых случаях синтаксис языка требует размещения оператора в какой-то конструкции, а по алгоритму у нас должно быть несколько операторов.

Составной оператор позволяет рассматривать группу операторов как один, используя ключевые слова(операционные скобки)- begin … end.

Вопрос №18

Оператор цикла с предусловием.

Оператор цикла с предусловием, начинающийся с ключевого слова while, содержит в себе выражение, которое управляет повторным выполнением оператора (который может быть составным оператором). Выражение, с помощью которого осуществляется управление повторением оператора, должно иметь булевский тип. Вычисление его производится до того, как внутренний оператор будет выполнен. Внутренний оператор выполнятся повторно до тех пор, пока выражение принимает значение Тruе. Если выражение с самого начала принимает значение False, то оператор, содержащийся внутри оператора цикла с предусловием, не выполняется.

Оператор цикла с предусловием имеет следующую структуру:

while <условие> do <оператор> 

где <условие> – выражение логического типа; <оператор> – произвольные операторы Паскаля. Если <условие> принимает значение True, то выполняется <оператор>; после чего вычисление выражения <условие> и его проверка повторяются.

Вопрос №19

Оператор цикла с постусловием.

В операторе цикла с постусловием, начинающимся со слова repeat, выражение, которое управляет повторным выполнением последовательности операторов содержится внутри оператора repeat. Результат выражения должен быть булевского типа. Последовательность операторов выполнится по крайней мере один раз, поскольку вычисление выражения производится после каждого выполнения последовательности операторов.

Оператор цикла repeat...until с постпроверкой условия имеет следующую структуру: REPEAT <тело_цикла> UNTIL <условие>.

Здесь REPEAT, UNTIL зарезервированные слова (повторять до тех пор пока не будет выполнено условие); <тело_цикла> – произвольная послед-ть операторов Турбо Паскаля; <условие> – выражение логического типа.

Операторы <тело_цикла> выполняются хотя бы один раз, после чего вычисляется выражение <условие>: если его значение есть FALSE, опе­раторы <тело_цикла> повторяются, в противном случае оператор REPEAT...UNTIL завершает свою работу.

Вопрос №20

Оператор цикла с фиксированным числом шагов.

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

Счетный оператор цикла FOR имеет такую структуру:

for <пар_цик> := <нач_знач> to <кон_знач> do <onepamop>

Здесь for, to, do зарезервированные слова (для, до, выполнить);

<пар_цик> – параметр цикла – переменная типа INTEGER (точнее, любого порядкового типа); <нач_знач> – начальное значение – выражение того же типа; <кон_знач> – конечное значение – выражение того же типа; <оператор> – произвольный оператор Турбо Паскаля. При выполнении оператора FOR вначале вычисляется выражение <нач_зчач> и осуществляется присваивание <пар_цик>:=<нач_знач>. После этого циклически повторяется

  • проверка условия <пар_цик> <= <кон_знач>; если условие не выполнено, оператор FOR завершает свою работу;

  • выполнение оператора <оператор>;

  • наращивание переменной <пар_цик> на единицу.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]