在线性时间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 好听的元旦简短祝福语