如果数组中的某个数字在我们将数字垂直和水平旋转 180 度后变成另一个也存在于数组中的数字,则会令人困惑。例如,如果我们将 6 垂直和水平旋转 180 度,它会变成 9,反之亦然。
我们必须记住,只有旋转 0、1、6、8、9 才能产生有效数字。
我们需要编写一个 JavaScript 函数,它接受一个自然数 num 作为第一个也是唯一的参数。该函数应首先构造一个包含 num 以内的所有自然数的数组,包括 num。
例如,对于 num = 5,数组应该是 -
[1, 2, 3, 4, 5]
然后该函数应该计算数组中存在多少令人困惑的数字,并最终返回该计数。
例如 -
如果输入是 -
const num = 10;
那么输出应该是 -
const output = 5;
因为数组将是: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] 并且容易混淆的数字是 -
1, 6, 8, 9, 10
此代码将是 -
const num = 10; const countConfusing = (num = 1) => { let count = 0; const valid = '01689'; const rotateMap = {'0': '0', '1': '1', '6': '9', '8': '8', '9': '6'}; const prepareRotation = num => { let res = ''; const numArr = String(num).split(''); if(numArr.some(el => !valid.includes(el))){ return false; }; numArr.map(el => { res = rotateMap[el] + res; }); return +res; }; for(let i = 1; i <= num; i++){ const rotated = prepareRotation(i); if(rotated && rotated > 0 && rotated <= num){ count++; }; }; return count; }; console.log(countConfusing(num));输出结果
控制台中的输出将是 -
5