Back to questions
Middle
1
function recursiveFunction(N) { let counter = 0; if (N > 0) { counter = counter + 1; recursiveFunction(N - 1); } // console.log(counter) } recursiveFunction(3); // 3 3 3 ? Explain what the output of the function will be and why. Also, identify any issues with the current implementation of the recursive function and suggest how to fix it to correctly count and log the number of recursive calls.
Companies where asked
Сбермаркетинг
Answer from AI
sobes.tech AI
В текущей реализации функции:
function recursiveFunction(N) {
let counter = 0;
if (N > 0) {
counter = counter + 1;
recursiveFunction(N - 1);
}
// console.log(counter)
}
recursiveFunction(3);
переменная counter инициализируется заново при каждом вызове функции, поэтому она не накапливает значение между вызовами. В итоге, даже если раскомментировать console.log(counter), на каждом уровне рекурсии будет выводиться 1 или 0, а не общее количество вызовов.
Также, функция ничего не возвращает и не выводит итоговое значение.
Чтобы корректно считать количество вызовов рекурсии, можно сделать так:
function recursiveFunction(N) {
if (N <= 0) return 0;
return 1 + recursiveFunction(N - 1);
}
const count = recursiveFunction(3);
console.log(count); // 3
Здесь функция возвращает количество вызовов, суммируя 1 за текущий вызов и результат рекурсивного вызова. В итоге выводится общее количество вызовов — 3.