在线性时间JavaScript中查找数组中的第一个重复项

我们需要编写一个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