add: 数据流中第一个唯一的数字

This commit is contained in:
2020-05-14 18:03:49 +08:00
parent 8f84fc8c66
commit 9c2a165583
3 changed files with 35 additions and 1 deletions

View File

@ -0,0 +1,23 @@
/**
* @param nums: a continuous stream of numbers
* @param number: a number
* @return: returns the first unique number
*/
export const firstUniqueNumber = function (nums, number) {
const due = new Set()
const queue = new Set()
for (const n of nums) {
if (queue.has(n)) {
queue.delete(n)
due.add(n)
} else if (!due.has(n)) {
queue.add(n)
}
if (n === number) break
}
if (!due.has(number) && !queue.has(number)) return -1
return Array.from(queue)[0] || -1
}