我想写一个函数(持久化),它接受一个正参数num并返回它的乘法持久性,这是你必须在num中乘以数字的次数,直到达到一个数字。 例如:递归闭包返回什么?
persistence(39) === 3 // because 3*9 = 27, 2*7 = 14, 1*4=4
// and 4 has only one digit
persistence(999) === 4 // because 9*9*9 = 729, 7*2*9 = 126,
// 1*2*6 = 12, and finally 1*2 = 2
persistence(4) === 0 // because 4 is already a one-digit number
我写了这个:
function persistence(num) {
//code me
var f;
f= countPersistence(num);
var toReturn= f(num); console.log("received value: "+toReturn);
return toReturn;
}
function countPersistence(num){
var count=0;
return function g(num){
var numt=num+"";
numt=numt.split("");
if(numt.length>1){
count++;
for(var i=0; i<numt.length-1; i++){
numt[i+1]=numt[i]*numt[i+1];
}
arguments.callee(numt[numt.length-1]);
}
else
{ console.log("returned value: "+count); return count;}
}
}
,你可以看到运行此代码,内部函数的返回值不完全是预期的。 确实,函数应该返回到它被调用的地方,对吧?但在这种情况下,因为它是递归的,所以它是从本身调用的。 我不知道如何检索实际值(不使用全局变量)
FYI:arguments.callee的已被弃用.... – epascarello