Страница 1 из 1

двойная рекурсия

Добавлено: 03 июл 2013, 19:36
ujif
помогите разобраться с двойной рекурсией
какие вызовы за какими следуют(с одинарной понятно)
например
procedure d(n:byte);
begin
if n=0 then exit
else
d(n-1);
d(n-1);
end;
n:=2;

Re: двойная рекурсия

Добавлено: 04 июл 2013, 17:21
Хыиуду
Проход по шагам (кнопка F8) вам в помощь

Re: двойная рекурсия

Добавлено: 09 июл 2013, 15:13
Naeel Maqsudov
Если с одинарной понятно, то какие проблемы? Когда произойдёт возврат из первого d(n-1), то только тогда та же самая канитель повторится еще раз. :)

Т.е. если при одинарном рекурсивном вызове d(n-1) у нас получается вырожденное в список дерево. Такую рекурсию можно смело заменить на цикл. (Что, к слову, компиляторы некоторых языком делают самостоятельно).

А если вызывать 2 раза, то получится классический обход сбалансированного бинарного дерева
d(2),d(1),d(0),d(0),d(1),d(0),d(0),d(2),d(1),d(0),d(0),d(1),d(0),d(0)