Im solving a codewars problem and im pretty sure i've got it working:
function digital_root(n) {
// ...
n = n.toString();
if (n.length === 1) {
return parseInt(n);
} else {
let count = 0;
for (let i = 0; i < n.length; i++) {
//console.log(parseInt(n[i]))
count += parseInt(n[i]);
}
//console.log(count);
digital_root(count);
}
}
console.log(digital_root(942));
Essentially it's supposed to find a "digital root":
A digital root is the recursive sum of all the digits in a number. Given n, take the sum of the digits of n. If that value has two digits, continue reducing in this way until a single-digit number is produced. This is only applicable to the natural numbers.
So im actually getting the correct answer at the end but for whatever reason on the if
statement (which im watching the debugger run and it does enter that statement it will say the return value is the correct value.
But then it jumps out of the if
statement and tries to return from the main digital_root
function?
Why is this? shouldn't it break out of this when it hits the if
statement? Im confused why it attempt to jump out of the if
statement and then try to return nothing from digital_root
so the return value ends up being undefined?