-
-
Notifications
You must be signed in to change notification settings - Fork 44
/
Copy pathtwice-linear.js
82 lines (77 loc) · 2.12 KB
/
twice-linear.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
// THIS ONE TIMES OUT!!
function dblLinear(n) {
// a place to store the sequence
const sequence = [1]; // start the sequence with 1
const seen = {};
// a place to keep track of the length, set to 0
let length = 0;
// a place to keep track of current x index, set to 0
let xIndex = 0;
// while length is less than n
while(length < n) {
const x = sequence[xIndex];
// calculate y given the current x
const y = 2 * x + 1;
// insert y into the sequence in sorted order
if (!seen[y]) {
for (var i = sequence.length - 1; i >= 0; i--) {
if (sequence[i] < y) {
break;
}
}
sequence.splice(i + 1, 0, y);
seen[y] = true;
}
// calcuate z given the current x
const z = 3 * x + 1;
// insert z into the sequence in sorted order
sequence.push(z);
seen[z] = true;
// increase length
length++;
// increase x index
xIndex++;
}
// return sequence at n
return sequence[n];
}
// DOES NOT TIME OUT - We are using less memory...
function dblLinear(n) {
// a place to store the sequence
const sequence = [1]; // start the sequence with 1
const seen = {};
// a place to keep track of the length, set to 0
let length = 0;
let last = 0;
// while length is less than n
while (length < n) {
const x = sequence.shift(); // remove first value from array
delete seen[x]; // remove from seen
// calculate y given the current x
const y = 2 * x + 1;
// insert y into the sequence in sorted order
if (!seen[y]) {
for (var i = last; i < sequence.length; i++) {
if (sequence[i] > y) {
break;
}
}
sequence.splice(i, 0, y);
seen[y] = true;
last = i;
}
// calcuate z given the current x
const z = 3 * x + 1;
// insert z into the sequence in sorted order
sequence.push(z);
seen[z] = true;
// increase length
length++;
}
return sequence[0]; // return the first value in the array
}
console.log(dblLinear(10), 22);
console.log(dblLinear(20), 57);
console.log(dblLinear(30), 91);
console.log(dblLinear(50), 175);
console.log(dblLinear(100), 447);