-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcountPins.ts
115 lines (93 loc) · 2.88 KB
/
countPins.ts
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
import { Pin } from './Pin';
export function countPinsBFS(m: number, n:number, pins:Array<Array<number>>, start:number) {
let network = {};
let pinsCreated = [];
function createPin(val) {
if (!network.hasOwnProperty(val)) {
let pin = new Pin(val);
network[val] = pin;
pinsCreated.push(val);
return pin;
} else {
return network[val];
}
}
pins.forEach(d => {
if (d.length === 2) {
createPin(d[0]);
let friend = createPin(d[1]);
network[d[0]].friends.push(friend);
} else if (d.length === 1) {
createPin(d[0]);
}
});
// BFS, use queue, then shift from queue and print degree from start
let queue = [];
let degree = 0;
queue.push(network[start]);
network[start].visited = true;
network[start].degree = degree;
let result = [];
let pinsVisited = [];
while (queue.length) {
let currentPin: Pin = queue.shift();
result.push(currentPin.degree);
pinsVisited.push(currentPin.val);
degree++;
currentPin.friends.forEach(p => {
if (!p.visited) {
queue.push(p);
p.visited = true;
p.degree = degree;
}
});
};
// Map all unvisited
let f = pinsCreated.filter(v => { return pinsVisited.indexOf(v) === -1 }).map(v => network[v].degree);
return result.concat(f);
}
export function countPinsDFS(m: number, n:number, pins:Array<Array<number>>, start:number) {
let network = {};
let pinsCreated = [];
function createPin(val) {
if (!network.hasOwnProperty(val)) {
let pin = new Pin(val);
network[val] = pin;
pinsCreated.push(val);
return pin;
} else {
return network[val];
}
}
pins.forEach(d => {
if (d.length === 2) {
createPin(d[0]);
let friend = createPin(d[1]);
network[d[0]].friends.push(friend);
} else if (d.length === 1) {
createPin(d[0]);
}
});
console.log('network', network);
let stack = [];
let degree = 0;
stack.push(network[start]);
network[start].visited = true;
network[start].degree = degree;
let visited = [];
while (stack.length) {
let currentPin = stack.shift();
visited.push(currentPin.val);
degree++;
currentPin.friends.forEach(f => {
if (f.visited === false) {
stack.push(f);
f.visited = true;
f.degree = degree;
}
});
}
let result = visited.map(p => network[p].degree);
let delta = pinsCreated.filter(v => visited.indexOf(v) === -1).map(p => network[p].degree);
return result.reverse().concat(delta);
}