写出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, '返回对数数组')
还有其他的计算写法,但是出于代码量及运行性能考虑,推荐使用这两种之一。