Предмет: Информатика,
автор: Coospir
Задание: сделать функцию определения того, что данное число является факториалом: function reversef (f: integer; var n: integer): boolean (возвращает
true, если f – факториал, n – число, факториалом которого является f.
Ответы
Автор ответа:
0
function reversef(f:integer; var n:integer):boolean;
var
i,k:integer;
p:longint;
begin
if f=1 then begin reversef:=true; n:=1 end
else begin
k:=2;
repeat
p:=1;
for i:=2 to k do p:=p*i;
if p<f then Inc(k)
until p>=f;
if p=f then begin reversef:=true; n:=k end
else begin reversef:=false; n:=-1 end
end
end;
var
i,k:integer;
p:longint;
begin
if f=1 then begin reversef:=true; n:=1 end
else begin
k:=2;
repeat
p:=1;
for i:=2 to k do p:=p*i;
if p<f then Inc(k)
until p>=f;
if p=f then begin reversef:=true; n:=k end
else begin reversef:=false; n:=-1 end
end
end;
Автор ответа:
0
спасибо
Автор ответа:
0
Для "спасибо" тут принято использовать синюю кнопочку.
Автор ответа:
0
k:=2;
repeat
p:=1;
for i:=2 to k do p:=p*i;
if p<f then Inc(k)
Что делает этот фрагмент кода.
repeat
p:=1;
for i:=2 to k do p:=p*i;
if p<f then Inc(k)
Что делает этот фрагмент кода.
Автор ответа:
0
что такое k? и что такое p?
Автор ответа:
0
Ну вот.... напиши сначала, а потом объясняй каждую строку? Факториалы он считает, начиная от 2! и сравнивает значение с заданным, пока не совпадет или не превысит.
Похожие вопросы
Предмет: Математика,
автор: qarayevaziyafet001
Предмет: Русский язык,
автор: safarovelmir019
Предмет: Английский язык,
автор: salimgirejnagmailcom
Предмет: Литература,
автор: глупышка22