我们需要编写一个JavaScript函数,该函数接受一个n +1介于1和n之间的整数的只读数组。
函数应该找到一个线性时间重复的数字,最多使用O(n)空间。
例如,如果输入数组是-
const arr = [3 4 1 4 1];
那么输出应该是-
const output = 1;
如果有多个可能的答案(如上述),我们应该输出任何一个。如果没有重复项,则应输出-1。
const arr = [3, 4, 1, 4, 1]; const findRepeatedNumber = (arr = []) => { const set = new Set(); for (const item of arr) { if (set.has(item)){ return item; }; set.add(item); }; return -1; }; console.log(findRepeatedNumber(arr));
输出结果
这将产生以下输出-
4