BEGIN write your solution here function solution str let result let wo

 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
// BEGIN (write your solution here)
function solution(str) {
let result = [];
let word = '';
let state = 'before';
for(let i = 0; i < str.length; i += 1) {
const symbol = str[i];
switch(state) {
case 'before':
// Если текущий символ не пробел и не перевод строки, то значит мы входим в первое слово.
// Надо сменить состояние и посчитать первый символ первого слова:
if (symbol !== ' ' && symbol !== '\n') {
state = 'in';
word += symbol;
}
break;
case 'in':
// Если текущий символ пробел, значит мы вышли из первого слова.
// Надо сменить состояние на "после слова", занести полученное слово в результат и обновить переменную word
if (symbol === ' ') {
state = 'after';
result.push(word);
word = '';
// Если текущий символ это перевод строки, значит мы вышли из первого слова и сразу же попали на новую строку
// Надо сменить состояние на "до слова" (ведь мы на новой строке), занести слово в результат и обновить word
} else if (symbol === '\n') {
state = 'before';
result.push(word);
word = '';
}
// Если текущий символ не пробел и не перевод строки, значит это часть первого слова
// Считаем его
else {
word += symbol;
// Если текущий символ является последним символом во всем массиве и при этом это не пробел и не перевод строки,
// то наша программа просто не занесет текущее слово в результат.
// Ведь запись слова в результат происходит только при столкновении с пробелом или переводом строки, а здесь этого нет.
// На следущей итерации массив закончится и мы просто выйдем из цикла, не сохранив последнее слово.
// Поэтому надо ввести условие на этот случай.
if (i === str.length - 1) {
result.push(word);
state = 'after';
}
}
break;
case 'after':
// Если текущий символ это символ перевода строки, то мы переходим на новую строку
// Надо сменить состояние на "до слова"
if (symbol === '\n') {
state = 'before';
}
break;
}
}
return result;
}
export default solution;
// END