• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Целое натуральное, рекурсия, Паскаль

Christian

Новые
Регистрация
20 Май 2012
Сообщения
12
Реакции
0
Баллы
0
Целое натуральное, рекурсия, Паскаль

если будет время то посмотрите пожалуйста эту задачу:

Задано целое натуральное число, определить является ли оно факториал числа n, чему равна n. Использовать рекурсивную функцию вычисления факториала
 
вот как-то так:
Код:
var
a:integer;
function fact(b:integer):integer;
var
c:longint;
i:integer;
begin
c:=1;
for i:=2 to b do begin
c:=c*i;
if c=b then break;
fact:=i+1;
end;
end;
begin
writeln ('Input the number');
readln (a);
writeln (a,' - fact - ',fact(a));
readln
end.
 
Не, Миш - не пойдёт. Тут фишка в том, что требуется рекурсивная функция, т.е. такая, которая из себя сама себя вызывает. Типа такой:
Код:
Function factorial(n:integer): Longint; 
Begin 
 If n=0 then factorial:=1 else factorial:=factorial(n-1)*n; 
End;
 
Назад
Сверху