-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfizz-buzz-tree.js
67 lines (54 loc) · 1.72 KB
/
fizz-buzz-tree.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
67
'use strict';
class KaryNode {
constructor(value, size) {
this.value = value;
this.children = new Array(size); // [undefined, undefined, undefined]
}
}
class KaryTree {
constructor(k) {
this.root = null;
this.k = k;
}
}
function fizzBuzzTree(kTree) {
let newTree = new KaryTree(kTree.k);
newTree.root = new KaryNode(kTree.root.value, kTree.k);
let current = kTree.root;
let current2 = newTree.root;
let queue = [];
let queue2 = [];
queue.unshift(current);
queue2.unshift(current2);
while (queue.length) {
current = queue.pop();
current2 = queue2.pop();
if (current.value % 15 === 0) { current2.value = 'FizzBuzz'; }
else if (current.value % 3 === 0) { current2.value = 'Fizz'; }
else if (current.value % 5 === 0) { current2.value = 'Buzz'; }
else { current2.value = current.value.toString(); }
for (let i = 0; i < current.children.length; i++) {
if (current.children[i]) {
current2.children[i] = new KaryNode(i, kTree.k);
queue.unshift(current.children[i]);
queue2.unshift(current2.children[i]);
}
}
}
return newTree;
}
// const karyTree = new KaryTree(3);
// karyTree.root = new KaryNode(0, karyTree.k);
// karyTree.root.children[0] = new KaryNode(4, karyTree.k);
// karyTree.root.children[1] = new KaryNode(7, karyTree.k);
// karyTree.root.children[2] = new KaryNode(7, karyTree.k);
// karyTree.root.children[0].children[0] = new KaryNode(4, karyTree.k);
// karyTree.root.children[0].children[1] = new KaryNode(5, karyTree.k);
// karyTree.root.children[1].children[2] = new KaryNode(6, karyTree.k);
// // karyTree.breadth();
// fizzBuzzTree(karyTree);
module.exports = {
node: KaryNode,
tree: KaryTree,
fb: fizzBuzzTree,
};