Задать вопрос
BeriaFantom
@BeriaFantom
Full Stack Razrabotchik

Как вычисляется x * func(x, n — 1) (рекурсия)?

Почти не понимаю, как происходит рекурсия, сколько не читаю материал, все так абстрактно и не совсем "логично".
function func(x, n) {
  if (n != 1) { 
    return x * func(x, n - 1);
  } else {
    return x;
  }
}

alert(func(4, 3));


Вот почему этот код возвращает 64? это ведь не цикл! проверка должна идти один раз if (n != 1), но тут почему-то по другому. Но это ладно. Каким образом происходит вычисление выражения x * func(x, n - 1) ? Ведь если подставить 4 и 3, то получится 4 * func(4, 3 - 1). А это в свою очередь 4 * func(4, 2). И вот каким образом происходит умножение 4 на func(4,2)? что на что умножается? что возвращает функция до умножения и почему это так происходит? Спасибо за понимание! Надеюсь, я это пойму
  • Вопрос задан
  • 343 просмотра
Подписаться 1 Оценить Комментировать
Решения вопроса 3
@timfcsm
первый проход : 3!=1 => 4 * (func(4, 3-1))
второй проход: 2!=1 => 4 * (func(4, 1))
третий проход: 1==1 => возвращаем 4
во втором проходе подставляем 4 => 4*4 = 16, возвращаем 16
в первом проходе подставляем 16 => 4 * 16 = 64
Ответ написан
mbeloshitsky
@mbeloshitsky
Вебдев, систем оперейшонс, ж.д. автоматика
Для понимания рекурсии, нужно понимать модель вычисления - то есть, что куда подставляется транслятором Js и в каком порядке. После этого все будет достаточно несложно - нужно лишь действовать как на уроках математики - просто подставляйте числа на места переменных, а тело функции на место ее вызова и упрощайте то, что можно упростить до того момента, когда упрощать станет нечего.

Получается слегка длинно, но и программирование это уже не школьные задачки.
Ответ написан
Есть стек контекстов, который запоминает значения. Если не ошибаюсь, то ваша функция работает так:
1) Вызывается func(4,3)
n != 1, поэтому возвращается 4 * func(4, 2) (Запоминается в стеке контекстов)
2) Вызывается func(4,2)
n != 1, поэтому возвращается 4 * func(4,1) (Запоминается в стеке контекстов)
3) Вызывается func(4,1)
n === 1, поэтому возвращается x, то есть 4, и дальше срабатывает то, что запомнилось в стеке контекстов:
2) 4 * func(4,1), где func(4,1) = 4, поэтому 4 * 4 = 16
1) 4 * func(4,2), где func(4,2) = 16, поэтому 4 * 16 = 64
Кстати, про рекурсию
И закрепить
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
Разбиваем по шагам (для понимания работы рекурсии на машине нужно принимать во внимание работу стеков вызовов):
  1. [уровень стека 0] Вызов func(4, 3)
  2. [уровень стека 1] n == 1 ? Нет
  3. [уровень стека 1] Вызов func(4, 2)
  4. [уровень стека 2] n == 1 ? Нет
  5. [уровень стека 2] Вызов func(4, 1)
  6. [уровень стека 3] n == 1 ? Да
  7. [уровень стека 3] Возвращаем значение Х равное 4
  8. [уровень стека 2] Возвращаем значение выражения Х, умноженное на возвращенное значение (4 * 4), равное 16
  9. [уровень стека 1] Возвращаем значение выражения Х, умноженное на возвращенное значение (4 * 16), равное 64
  10. [уровень стека 0] Получаем 64
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы