Урок № 8
Тема: Встроенные математические функции языка Pascal. Правила записи математических выражений.
Встроенные математические функции языка Pascal
Математическая запись |
Запись на Pascal |
Назначение |
cos x |
cos(x) |
Косинус x радиан |
sin x |
sin(x) |
Синус x радиан |
ex |
exp(x) |
Значение e в степени x |
[x] |
trunc(x) |
Целая часть числа x |
|x| |
abs(x) |
Модуль числа x |
x2 |
sqr(x) |
Квадрат числа x |
|
sqrt(x) |
Квадратный корень из x |
{x} |
frac(x) |
Дробная часть x |
arctg x |
arctan(x) |
Арктангенс числа x |
ln x |
ln(x) |
Натуральный логарифм x |
|
Pi |
Число П |
Возведение в степень (кроме возведения в квадрат и возведения в степень числа e) отсутствует. Для возведения в произвольную степень можно воспользоваться очевидным равенством: xy=ey ln x. Для возведения числа в натуральную степень можно написать собственную функцию. Например,
{Функция возведения числа X в натуральную степень N}
Function Stepen(X : Real; N : Integer) : Real;
Var I : Integer; St : Real;
Begin
St := 1;
For I := 1 To N Do St := St * X;
Stepen := St;
End;
Другой способ получить натуральное значение z=xy, где x, y — натуральные, это сделать так: Z := Round(Exp(Y * Ln(X))).
Примечание. Интересной является задача получения степени любого целого числа (за исключением нуля), если основание степени — неотрицательное целое, без использования развилки. Одно из возможных решений : (–1)*Ord(Odd(Y)) * Exp(Y * Ln(X)) + Ord(Odd(Y+1)) * Exp(Y * Ln(X)). Здесь Ord(K) — функция, возвращающая порядковый номер величины K в том или ином порядковом типе (в примере использовано свойство, что порядковый номер False равен 0, а порядковый номер True — 1).
Математическая запись |
Запись на школьном алгоритмическом языке |
|
x*y/z |
|
x/(y*z) или x/y/z |
|
(a**3+b**3)/(b*c) |
|
(a[i+1]+b[i-1])/(2*x*y) |
|
(-b+sqrt(b*b-4*a*c))/(2*a) |
(x<0) |
sign(x)*abs(x)**(1/5) |
|
0.49*exp(a*a-b*b)+ln(cos(a*a))**3 |
|
x/(1+x*x/(3+(2*x)**3)) |
Арифметические выражения записываются по следующим правилам:
· Нельзя опускать знак умножения между сомножителями и ставить рядом два знака операций.
· Индексы элементов массивов записываются в квадратных (школьный АЯ, Pascal) или круглых (Basic) скобках.
· Для обозначения переменных используются буквы латинского алфавита.
· Операции выполняются в порядке старшинства: сначала вычисление функций, затем возведение в степень, потом умножение и деление и в последнюю очередь — сложение и вычитание.
· Операции одного старшинства выполняются слева направо. Например, a/b*c соответствует a/b*c. Однако, в школьном АЯ есть одно исключение из этого правила: операции возведения в степень выполняются справа налево. Так, выражение 2**(3**2) в школьном АЯ вычисляется как 2**(3**2) = 512. В языке QBasic аналогичное выражение 2^3^2 вычислясляется как (2^3)^2 = 64. А в языке Pascal вообще не предусмотрена операция возведения в степень, в Pascal x^y записывается как exp(y*ln(x)), а x^y^z как exp(exp(z*ln(y))*ln(x)).
Типичные ошибки в записи выражений:
5x+1 |
Пропущен знак
умножения между 5 и х |
Запишите по правилам алгоритмического языка выражения:
a) |
|
e) |
|
б) |
|
ж) |
|
в) |
|
з) |
|
г) |
|
и) |
|
д) |
|
к) |
|
Запишите в обычной математической форме арифметические выражения:
а)
a/b**2; |
л)
5*arctg(x)-arctg(y)/4; |
Логический операнд — это конструкция соответствующего языка программирования, которая задает правило для вычисления одного из двух возможных значений: True или False.
Чаще всего логические выражения используют в операторах присваивания или для записи того или иного условия. Составными частями логических выражений могут быть: логические значения (True, False); логические переменные; отношения.
Например, 1) Y:=True; 2) Z:=False; 3) LogPer:=A > B; 4) Log1:=(A = B) And (C <= D).
Как видно из примеров, отношение — это два выражения, разделенных между собой знаком операции отношения (>, <, =, <>, <=, >=). Отношение является простейшей конструкцией логического выражения. Оно вычисляет результат True, если выполняется заданное соотношение, и False — в противном случае.
Примечание. Несмотря на то, что операции отношения =, <>, >=, <= определены для вещественных типов, реально они в большинстве случаев корректно не работают в силу того, что множество вещественных величин, представимых в памяти ЭВМ, дискретно. Поэтому их следует, если это возможно, избегать. В том случае, когда всё-таки для вещественных возникает необходимость вычисления указанных отношений, разумно проверять вещественные величины не на равенство, а на близость расположения друг к другу, т.е. заменять отношения вида A=B отношениями вида |A-B|<E, где E — достаточно малое по абсолютной величине число (в общем случае — так называемое машинное епсилон).
В языке Pascal операции отношения определены для величин любого порядкового типа (целые, символьный, логический, перечислимый, диапазон). Операции отношения могут быть выполнены также над строковыми выражениями. Сравнение двух строк выполняется посимвольно слева направо в соответствии с их лексикографической упорядоченностью в таблице кодов ASCII. Эта упорядоченность предполагает, что "1"<"2", "a"<"b", "B"<"C" и т.д. Как только в процессе попарных сравнений символов с одинаковой порядковой позицией обнаруживается больший по коду ASCII символ, данный процесс прекращается, и считается, что строка с этим символом соответственно больше другой строки. Если строки имеют разную длину и их символы совпадают до последнего знака, то считается, что более короткая строка меньше.
Логическое выражение — это логический операнд или последовательность логических операндов, разделенных между собой знаками логических операций (NOT, AND, OR, XOR).
Порядок действий при вычислении значения логического выражения:
1) вычисляются значения в скобках;
2) вычисляются значения функций;
3) выполняется унарные операции (операция NOT);
4) выполняется операция AND;
5) выполняются операции OR, XOR;
6) выполняются операции отношения.
Действия выполняются слева направо с учетом их старшинства. Желаемая последовательность операций обеспечивается путем расстановки скобок в соответствующих местах выражения.
При реализации некоторых программ удобно использовать функции, которые имеют логическое значение. Обычно они используются для того, чтобы на некоторый вопрос получить ответ “ДА” или “НЕТ”.
Например, следующая функция возвращает True, если её аргумент — простое число, и False — в противном случае:
Function Simple (Pr : Integer) : Boolean;
Var I : Integer; LogPer : Boolean;
Begin I := 2; {счетчик}
Repeat
LogPer := (Pr Mod I = 0); {логическая переменная, принимающая значение TRUE,
если число Pr составное}
I := I + 1
Until (I > Pr Div 2 + 1) Or (LogPer);
{цикл завершаем в том случае, когда счетчик становится больше половины
данного числа или обнаруживаем, что число составное}
Simple := Not LogPer
{значение функции равно TRUE, если число простое, и FALSE — в противном случае}
End;
Индивидуальные задания для самостоятельной работы.
Тема: Запись арифметических выражений.
1. .Преобразуйте выражения из линейной формы в арифметическую.
D=(c-3*a*62)/18.5-(a**2+b^3)/(a-b)+(a+c**2)/(3*c**2);
W=(d+b*a**2-d/3.3+d**2/3-(b-a)**3/55)/(d-d**2);
2. Запишите арифметическое выражение в линейной форме.
1. . Преобразуйте выражения из линейной формы в арифметическую.
C=(b-w)/(a**2-2*b)-(w-b)/(a=b**2)+(b**3-a+w)/(a+b**2-w);
H=d**3-3*b-7.2*e*w+a**3*w*c;
2. Запишите арифметическое выражение в линейной форме.
1. Преобразуйте выражения из линейной формы в арифметическую.
W=(x/100.1+x/25)**2+a/(b-3.7*(b-3));
Z=(b-w)/(a**2-2*b)-(a+b**2-a+w)/(a+b**2-w);
2. Запишите арифметическое выражение в линейной форме.
1. Преобразуйте выражения из линейной формы в арифметическую.
B=9*a-(3*x)/z**2+(9*a+3*x)/(z**2);
X=42*a**2-(55.75^2*b)/28+a/(b-3.7(b-3);
2. Запишите арифметическое выражение в линейной форме.