blob: d48adbc821bc231c0c5a9cb0b3915115b4a6d1c5 (
about) (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
import { LinksByNodeId } from '../pages'
import { normalizeLinkEnds } from './normalizeLinkEnds'
export const findNthNeighbors = ({
ids,
excludedIds,
n,
linksByNodeId,
}: {
ids: string[]
excludedIds: string[]
n: number
linksByNodeId: LinksByNodeId
}) => {
let queue = [ids[0]]
let todo: string[] = []
const completed = [ids[0]]
Array.from({ length: n }, () => {
queue.forEach((node) => {
const links = linksByNodeId[node as string] ?? []
links.forEach((link) => {
const [sourceId, targetId] = normalizeLinkEnds(link)
if (excludedIds.some((id) => [sourceId, targetId].includes(id))) {
return
}
if (!completed.includes(sourceId)) {
todo.push(sourceId)
return
}
if (!completed.includes(targetId)) {
todo.push(targetId)
return
}
return
})
})
queue = todo
todo.forEach((neighbor) => neighbor && completed.push(neighbor))
todo = []
})
return completed
}
|