-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGraph.js
66 lines (51 loc) · 1.19 KB
/
Graph.js
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
class Graph {
constructor() {
this.nodes = {};
}
addNode(value, ...rest) {
this.nodes[value] = this.nodes[value] || [];
if (rest.length) this.addNode(...rest);
}
addEdge(v1, v2) {
if (!this.nodes[v1] || !this.nodes[v2]) return;
this.nodes[v1].push(v2);
this.nodes[v2].push(v1);
return this;
}
traverseDepthFirst() {
const visited = [];
const traverse = (node) => {
if (!this.nodes[node]) return;
if(visited.indexOf(node) === -1) {
visited.push(node);
this.nodes[node].forEach((each) => {
traverse(each);
});
}
};
for(let key in this.nodes) {
if(visited.indexOf(key) === -1) {
visited.push(key);
this.nodes[key].forEach((node) => {
traverse(node);
});
}
}
return visited;
}
traverseBreadthFirst() {
// loop through each key
// store in visited array
// push all children to toBeVisitedArray;
// after loop has aended
// Itereate over toBeVisitedArray
// make sure to exclude items that has been visited before
}
}
const graph = new Graph();
graph.addNode('olu', 'maintain', 'bola', 'sidi');
graph
.addEdge('olu', 'sidi')
.addEdge('olu', 'bola')
.addEdge('bola', 'maintain');
graph.traverseDepthFirst();