js笔试题--写出1-10000之间的对称数!
写出1-10000之间的对称数
知识普及一哈:一个整数,它的各位数字如果是左右对称的,则称这个数是对称数。例如:1234321、123321等。 对称数也叫做回文数。 一般来说,位数大于或等于两位。最小的对称数是11,没有最大的对称数,因为数位是无穷的。
写运算函数
//判断是否是对称数 let isSymmetry = function(num) { let sNum = num.toString(); let slength = sNum.length; for (let i = 0; i < slength / 2; i++) { if (sNum.charAt(i) !== sNum.charAt(slength - 1 - i) || slength < 2) { return false; } } return true; }
或者这样
//对称数的逆序数等于自身 let isSymmetry = function(num) { nInversionNumber = +(num.toString().split("").reverse().join("")); if (num === nInversionNumber && num >= 10) { return true; } return false; }
这样使用,最终拿到一个对称数的数组集合
//1-number之间的对数 let arr = [],number = 10000; for (let j = 0; j < number; j++) { isSymmetry(j) ? arr.push(j) : false } console.log(arr, 返回对数数组)
还有其他的计算写法,但是出于代码量及运行性能考虑,推荐使用这两种之一。