-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathColoured-Triangles.js
57 lines (48 loc) · 1.89 KB
/
Coloured-Triangles.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
/*
If you finish this kata, you can try Insane Coloured Triangles by Bubbler, which is a much harder version of this one.
A coloured triangle is created from a row of colours, each of which is red, green or blue.
Successive rows, each containing one fewer colour than the last, are generated by considering the two touching colours in the previous row. If these colours are identical, the same colour is used in the new row. If they are different, the missing colour is used in the new row. This is continued until the final row, with only a single colour, is generated.
The different possibilities are:
Colour here: G G B G R G B R
Becomes colour: G R B G
With a bigger example:
R R G B R G B B
R B R G B R B
G G B R G G
G R G B G
B B R R
B G R
R B
G
You will be given the first row of the triangle as a string and its your job to return the
final colour which would appear in the bottom row as a string. In the case of the example above, you would the given RRGBRGBB you should return G.
The input string will only contain the uppercase letters R, G, B and there will be at least one letter so you do not have to test for invalid input.
If you are only given one colour as the input, return that colour.
Adapted from the 2017 British Informatics Olympiad
*/
// Answer:
function triangle(row) {
let left = 0;
let right = 1;
let temp = "";
while (row.length > 1) {
temp += findColor(row[left], row[right]);
left += 1;
right += 1;
if (right >= row.length) {
row = temp;
temp = '';
left = 0;
right = 1;
}
}
return row;
}
const findColor = (c1,c2) => {
if (c1 === c2) return c1;
const colors = c1 + c2;
if (!colors.includes('R')) return 'R'
if (!colors.includes('G')) return 'G'
if (!colors.includes('B')) return 'B'
}
// BigO: O(n)