在线性时间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
热门推荐
6 保研的祝福语简短
10 年轻20岁祝福语简短
11 朋友结婚祝福语信息简短
12 女孩婚礼贺卡祝福语简短
13 30段点歌简短祝福语
14 虎年春节祝福语图文简短
15 写给后妈祝福语大全简短
16 简短回复生日祝福语
17 校长送毕业祝福语简短
18 毕业立体贺卡祝福语简短