在线性时间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
热门推荐
10 朋友被录取祝福语简短
11 新车新家祝福语大全简短
12 感恩父亲贺卡祝福语简短
13 幼儿对父亲简短祝福语
14 关于石榴的祝福语简短
15 搬家祝福语卡片文案简短
16 女儿升学宴祝福语简短
17 新婚祝福语简短老同学
18 团体年会祝福语简短霸气