Вы должны написать программу или функцию, которая получает строку, представляющую искусство ASCII, в качестве входных данных и выводит или возвращает количество конечных точек во входных данных.
Ввод будет состоять из символов space - | +
(с 0, 2, 2 и 4 конечными точками соответственно) и разрывов строк. Например:
-|++-
+
Два смежных символа связаны и, следовательно, теряют 1 конечную точку каждый в следующих случаях:
-- -+ +- | | + + ++
| + | +
Первый пример имеет
2+2+2+2+1+
3 = 12
конечные точки.
вход
- Ввод будет строка , состоящая из символов пространства,
-
,|
,+
и символ новой строки. - Длина ввода может быть равна 0, и любой вход, соответствующий приведенному выше описанию, действителен (в регулярных выражениях ввод
[ -+|\n]*
). - Трейлинг новой строки не является обязательным.
Выход
- Одно неотрицательное целое число, количество конечных точек.
Примеры
Выходы идут после последнего ряда их входов.
+
4
-|++-
+
12
+--+
| |
+--+
8
| |
+--+-- |||
12
--++
|||--
10
<empty input>
0
|
|
2
--
++--
++
--+
+++ ||
----
30
Это код гольф, поэтому выигрывает самый короткий вход.
["",...s.split("\n"),""]
это дольше @ETHproductions