Function fact(i:integer):longint;
begin
if (i=0) or (i=1) then
fact:=1
else
fact:=fact(i-1)*i
end;
Объясните, пожалуйста, как она работает (ведь это рекурсия?)
1. Заголовок или название темы должно быть информативным !
2. Все тексты фрагментов программ должны помещаться в теги [code] ... [/code] или [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ" и используйте ПОИСК !
4. НЕ используйте форум для личного общения!
5. Самое главное - это раздел теоретический, т.е. никаких задач и программ (за исключением небольших фрагментов) - для этого есть отдельный раздел!
Рекурсия |
Client |
Сообщение
#1
|
Профи Группа: Пользователи Сообщений: 865 Пол: Мужской Реальное имя: Вячеслав Репутация: 20 |
Function fact(i:integer):longint; Объясните, пожалуйста, как она работает (ведь это рекурсия?) |
Client |
Сообщение
#2
|
Профи Группа: Пользователи Сообщений: 865 Пол: Мужской Реальное имя: Вячеслав Репутация: 20 |
Вопрос из теста: Какие из следующих описаний функции f(n), каторая должна вычислять факторил от n правильны?
а) function f(n:integer):integer; б) function f(n:integer):integer; в) function f(n:integer):integer; г) function f(n:integer):integer; В первом случае она зависнет Во втором вроде тоже зависнет, т.к. N не уменьшется и вызывается все время f(1) В третьем посчитает неправильно, допустим n=5,то 5*4*f(3)*f(1), здесь пропустится f(2) В четвертом вроде все правильно Скажите, пожалуйста, где я ошибся |
Текстовая версия | 9.05.2024 6:08 |