При определении значений подобных функций переменная y вычисляется по-разному (по разным формулам) в зависимости от значения x.
Такие задачи решаются с конструкции условного оператора if - else. Поскольку в данном случае мы имеем три условия (x > 0, x = 0 и x < 0), то потребуется использование еще вложенной конструкции if - else, т. к. в языке Pascal нет оператора множественного ветвления (оператор case в данном случае не подходит).
В языке программирования Паскаль (да и в других тоже) желательно вложенные конструкции if - else помещать во внешнюю ветку else, а не if. Так проще не запутаться.
Таким образом, алгоритм вычисления значения функции может быть таким:
Если x > 0, то у = x - 2
Иначе (ниже идет вложенная конструкция)
Если x = 0, то y = 0
Иначе y = |x|.
В последнем пункте можно опустить оператор if с проверкой, что x < 0, так как если ход выполнения программы дошел до этого пункта, то x уже другим быть и не может (варианты, когда он больше или равен нулю, уже были исключены).
Для определения модуля (абсолютного значения) переменной можно использовать встроенную функцию abs() языка Pascal. В данном случае можно обойтись и без нее: поскольку уже известно, что x отрицателен, то, чтобы получить положительное число (модуль), нужно его умножить на -1.
Объяснение:
вроде так
Задание 1:
var i:integer;
begin
for i:=1 to 20 do writeln('2^',i,'=',exp(i*ln(2)):0:0)
end.
Задание 2:
Мало деталей...N чисел вводятся вручную или они генерятся автоматически рандомно?
var i,min,n,x:integer;
begin
min:=9999;
write('Количество чисел: '); readln(n);
for i:=1 to n do begin
write('Введите ',i,'-е число: '); readln(x);
if x < min then min:=x
end;
write('Минимальное из введённых чисел равно ', min);
end.
Задание 3:
var i,x:integer;
chk:boolean;
begin
chk:=True;
write('Введите натуральное число: '); readln(x);
for i:=2 to x-1 do begin
if x mod i = 0 then begin
chk:=False;
break;
end;
end;
if chk = True then write('Введённое число является простым.')
else write('Введённое число не является простым.');
end.