Javascript 返回数组中所有回文数的总和
我试图用javascript获取数组中回文数的总和 代码获取输出0,而不是回文值的总和: 功能逆转{ var-rem,res=0 当n>0时{ rem=n%10 res=res*10+rem n=n/10 } 返回res } 功能定位仪{ 如果n==reversen,则返回true } sumArrayarr函数{ var总和=0 对于变量i=0;iJavascript 返回数组中所有回文数的总和,javascript,arrays,function,palindrome,Javascript,Arrays,Function,Palindrome,我试图用javascript获取数组中回文数的总和 代码获取输出0,而不是回文值的总和: 功能逆转{ var-rem,res=0 当n>0时{ rem=n%10 res=res*10+rem n=n/10 } 返回res } 功能定位仪{ 如果n==reversen,则返回true } sumArrayarr函数{ var总和=0 对于变量i=0;i10&&isAlindromearr[i]{ 总和+=arr[i] } } console.logsum; } sumArray[12313,11
console.log 313+11+44 问题在于您的反向函数。n=n/10留下了一些混乱的小数,导致循环没有终止
while (n > 0) {
rem = n % 10
res = res * 10 + rem
n = n / 10
}
只要舍入这个结果,代码就会按预期运行
while (n > 0) {
rem = n % 10
res = res * 10 + rem
n = Math.round(n / 10)
}
下面是进行舍入更改的代码
功能逆转{
var-rem,res=0
当n>0时{
rem=n%10
res=res*10+rem
n=Math.round n/10
}
返回res
}
功能定位仪{
如果n==reversen,则返回true
}
sumArrayarr函数{
var总和=0
对于变量i=0;isumArray[12313,11,44,9,1]问题在于反向函数内部。n=n/10留下了一些混乱的小数,导致循环没有终止
while (n > 0) {
rem = n % 10
res = res * 10 + rem
n = n / 10
}
只要舍入这个结果,代码就会按预期运行
while (n > 0) {
rem = n % 10
res = res * 10 + rem
n = Math.round(n / 10)
}
下面是进行舍入更改的代码
功能逆转{
var-rem,res=0
当n>0时{
rem=n%10
res=res*10+rem
n=Math.round n/10
}
返回res
}
功能定位仪{
如果n==reversen,则返回true
}
sumArrayarr函数{
var总和=0
对于变量i=0;isumArray[12313,11,44,9,1]您可以简化回文的确定,并使用Array.reduce来确定和 常量isPalindrome=n=> n>10&&`${n}`==[…`${n}`].reverse.join?n:0; const sumOfPalindromes=arr=> arr.reduceacc,val=>acc+isPalindromeval,0;
控制台。停车场日志[12313,11,44,9,1] 您可以简化回文确定,并使用Array.reduce确定和 常量isPalindrome=n=> n>10&&`${n}`==[…`${n}`].reverse.join?n:0; const sumOfPalindromes=arr=> arr.reduceacc,val=>acc+isPalindromeval,0;
控制台。停车场日志[12313,11,44,9,1];所以isPalindrome或reverse都可能不起作用。你已经测试过这两个了吗?我不明白为什么人们如此渴望做别人的功课。这是一个基本上合理的问题,但应该用可教的时刻和调试技巧来回答,而不是用盘子上的答案。所以很可能isPalindrome或reverse都不起作用。你测试过这两个吗?我不明白为什么人们如此渴望做别人的家庭作业。这是一个基本上合理的问题,但应该用可教的时刻和调试技巧来回答,而不是用盘子上的答案。请重新验证你的代码一次,答案应该是368,而不是378是的,一时分心请重新验证你的代码一次,答案应该是368,而不是378是的,一时分心