Паскаль , делал с формулировкой "напишите процедуру подсчёта суммы вещественных чисел a, b, c, d". я написал, но выводится какое-то огромное число. искал решения в сети и там при выведении суммы есть строчка: writeln('сумма чисел равна ',rez: 0: 2); что означает это 0: 2 ?
В приведенном ниже примере значение 4.03099999999977E+0001 читается следующим образом: .
Для того, чтобы получать вывод в "привычном" виде, можно использовать форматирование. Для этого, в операторе вывода после значения переменной указывается конструкция вида m:n, где m- общее количество позиций, отводимое под запись числа (если 0 - то количество позиций определяется автоматически так, чтобы число поместилось), а n- количество позиций, отводимое под дробную часть.
Такая запись может применяться как для общего описателя типа вещественных чисел real, так и для конкретного (например, double - чисел "двойной точности", т.е. восьмибайтных). В примере хорошо видно, как использование двойной точности отражается на выводе результата в "научном" формате .
Пример на Турбо Паскаль
{$G+,N+}
uses Crt;
procedure Sum1(a,b,c,d:real;var r:real);
begin
r:=a+b+c+d
end;
procedure Sum2(a,b,c,d:double;var r:double);
begin
r:=a+b+c+d
end;
var
e,f,g,h,res1:real;
p,q,r,s,res2:double;
begin
ClrScr;
Write('e f g h= '); Read(e,f,g,h);
Sum1(e,f,g,h,res1);
Writeln('res1= ',res1,' = ',res1:0:2);
Write('p q r s= '); Read(p,q,r,s);
Sum2(p,q,r,s,res2);
Writeln('res2= ',res2,' = ',res2:0:2);
ReadKey
end.
Тестовое решение:
e f g h= 12.74 24.17 -5.6 9
res1= 4.03099999999977E+0001 = 40.31
p q r s= 12.74 24.17 -5.6 9
res2= 4.03100000000000E+0001 = 40.31