C++ рекурсивная функция:

программирование C++

Имеется простая функция факториал:

long factorial (long a)
{
if (a > 1)
return (a * factorial (a-1));
else
return (1);
}


Вопрос: КАК она возвращает правильное начение, т. к. 'a' все время уменьшается, и в конце функция возвращает 1 [ return (1); ] а не
return factorial?

Примечание:
Извините, неправильно задал вопрос, задам заного...
Ответы:
факториал это произведение последовательности чисел, т.е. 1*2*3*4*5.... причем не важно с какой стороны начинать умножение, вот и получается что в вашей функции произведение производиться с наибольшего элемента, а в конце возвращается 1.
ну вот пример для 3:
3*(3-1)*1 -> 1*2*3
Параметры в C передаются не по фиксированному адресу, а через стек. При каждом новом вызове переменная a обозначает новую ячейку памяти. При рекурсивном вызове стек заполняется цепочкой фреймов, содержащих адрес возврата и параметр вызова функции.


15 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.