Условие:
Вот решение задчи через функции:
program searsdfg;
uses crt;
function f1(x:real):real;
begin
f1:=x*x*x;
end;
function f2(x,y,z:real):real;
begin
if (x>y) and (x>7) then f2:=x;
end;
function f3(x,y:real):real;
begin
if x>y then f3:=x;
end;
function f4(y:real):real;
begin
f4:=y*y*y;
end;
var x,y,c:real;
begin
clrscr;
writeln('x=?');
readln(x);
writeln('y=?');
readln(y);
c:=(f1(x)+(x+f4(y))*sqrt((x*f4(y))+f1(x))/(f2(x,x*y,x+y)+f3(x,x*y)));
writeln;
writeln('c=',c:2:2);
readln;
end.
Дружище проверь все условия они у тебя лажовые очень я бы даже сказал... дай нормальное условие задачи и что за функция max ее можно как угодно написать?... Короче дай нормальное задание!
max(x,xy,x+y) означает найти наибольшее из перечисленных в скобках чисел.
function max(x,y:real):real;А вызов
begin
if x>y then max:=x
else max:=y
end;
max(max(x,y),z)
Нет вы меня непоняли, задача в первом посте решена верно, только нужно переделать её так чтоб она была решена не функциями а процедурами. вместо function должны быть procedure
function f3(x,y:real):real;
begin
if x>y then f3:=x;
end;
Аха дейсвительно ошибся.
Вот правильная задача через функции (уже провереная), необходимо записать её через процедуры. (так чтобы и в том и в том решении с одинаковыми даными выводило одинаковый ответ).
program rsdfew;
uses crt;
function f1(x:real):real;
begin
f1:=x*x*x;
end;
function f2(x,y,z:real):real;
begin
if (x>y) and (x>z) then f2:=x;
if (y>x) and (y>z) then f2:=y;
if (z>x) and (z>y) then f2:=z;
end;
function f3(x,y:real):real;
begin
if x>y then f3:=x else f3:=y;
end;
function f4(y:real):real;
begin
f4:=y*y*y;
end;
var x,y,c:real;
begin
clrscr;
writeln('x=?');
readln(x);
writeln('y=?');
readln(y);
c:=(f1(x)+(x+f4(y))*sqrt((x*f4(y))+f1(x))/(f2(x,x*y,x+y)+f3(x,x*y)));
writeln;
writeln('c=',c:2:2);
readln;
end.
program rsdfew;
uses crt;
procedure p1(x:real; var f1:real );
begin
f1:=x*x*x;
end;
procedure p2(x,y,z:real; var f2:real);
begin
if (x>y) and (x>z) then f2:=x;
if (y>x) and (y>z) then f2:=y;
if (z>x) and (z>y) then f2:=z;
end;
procedure p3(x,y:real; var f3:real);
begin
if x>y then f3:=x else f3:=y;
end;
procedure p4(y:real; var f4:real);
begin
f4:=y*y*y;
end;
var f1,f2,f3,f4,z,x,y,c:real;
begin
clrscr;
writeln('x=?');
readln(x);
writeln('y=?');
readln(y);
p1(x,f1);p2(x,y,z,f2);p3(x,y,f3);p4(y,f4);
c:=(f1+(x+f4)*sqrt((x*f4)+f1)/(f2+f3));
writeln;
writeln('c=',c:2:2);
readln;
end.
program rsdfew;
uses crt;
var f1,f2,f3,f4:real;
procedure p1(q:real; var f1:real );
begin
f1:=q*q*q;
end;
procedure p2(q,w,e:real; var f2:real);
begin
if (q>w) and (q>e) then f2:=q;
if (w>q) and (w>e) then f2:=w;
if (e>q) and (e>w) then f2:=e;
end;
procedure p3(q,w:real; var f3:real);
begin
if q>w then f3:=q else f3:=w;
end;
procedure p4(w:real; var f4:real);
begin
f4:=w*w*w;
end;
var
x,y,z,c:real;
begin
clrscr;
writeln('x=?');
readln(x);
writeln('y=?');
readln(y);
p1(x,f1);
p2(x,x*y,x+y,f2);
p3(x,x*y,f3);
p4(y,f4);
c:=(f1+(x+f4)*sqrt((x*f4)+f1)/(f2+f3));
writeln;
writeln('c=',c:2:2);
readln;
end.