Санта нуждается в некоторой помощи, чтобы определить, сколько эльфов ему понадобится, чтобы помочь ему доставить подарки в каждый дом.
Уголь значительно тяжелее подарков, поэтому Санте понадобятся три эльфа на каждого непослушного человека в доме. Только два эльфа нужны, чтобы помочь Санте нести подарки.
На карте Санты дом представлен как *
, а каждый дом разделен на +
.
По обе стороны от дома будет цифра: слева - число непослушных людей в доме, а справа - количество милых людей в доме. Если на одной стороне нет числа, оно интерпретируется как 0.
Санта не посещает тех, кто не в духе Рождества (они даже не заслуживают угля), поэтому иногда дом может не иметь номера по обе стороны от него. В этом случае Санта не нуждается в помощи от каких-либо эльфов
Например, одна из карт Санты может выглядеть так
1*3+2*2+1*+*2
В первом доме 1 озорной и 3 милых, Санте понадобится девять эльфов. Во втором, 2 непослушных и 2 милых, Санте понадобится десять эльфов. В третьем доме 1 непослушный и 0 симпатичных, Санте понадобятся три эльфа, а в последнем доме 0 непослушных и 2 симпатичных, Санте понадобятся четыре эльфа.
Однако это упрощенная версия одной из карт Санты. Обычно карты Санты состоят из нескольких строк и имеют квадратную форму, чтобы лучше соответствовать его списку. Карта нормалей может выглядеть примерно так ( \n
в конце каждой строки)
1*2+*+*4+1*
2*4+3*+1*6+*
*+*+4*2+1*1
*4+*3+1*+2*3
3*10+2*+*5+*
На этой карте Санта ((1 + 0 + 0 + 1 + 2 + 3 + 1 + 0 + 0 + 0 + 4 + 1 + 0 + 0 + 1 + 2 + 3 + 2 + 0 + 0) * 3) + ((2 + 0 + 4 + 0 + 4 + 0 + 6 + 0 + 0 + 0 + 2 + 1 + 4 + 3 + 0 + 3 + 10 + 0 + 5 + 0) * 2)
= 151 эльф
Вызов
Помоги Санте определить, сколько эльфов ему нужно, чтобы доставить товар в каждый дом!
дома
- Дом представлен
*
- Дома делятся на
+
- Число слева от дома символизирует количество непослушных людей (число не означает 0)
- Число справа символизирует количество приятных людей (число не означает 0)
- Во
\n
входе могут быть символы новой строки ( ), которые также следует обрабатывать как разделенные
Эльфы
- Санта нуждается в помощи трех эльфов для непослушных людей (уголь намного тяжелее подарков)
- Санта нуждается в помощи двух эльфов для хороших людей
- Если с обеих сторон не будет номера, Санта не будет посещать этот дом, и поэтому ему не нужны никакие эльфы.
Что делать
Выведите количество эльфов, которым Санта должен помочь доставить подарки в дома. Поскольку Санта должен знать, сколько эльфов нужно принести, вам нужно всего лишь напечатать добавленное количество эльфов, которое ему нужно для списка домов.
Тестовые случаи
1*1 => 5
1*2 => 7
2*1 => 8
1* => 3
*1 => 2
* => 0
1*1+1*1 => 10
1*2+2*1 => 15
1*+*1 => 5
1*1+*+1*1 => 10
*+*+*+* => 0
правила
- Входные данные могут быть либо взяты в качестве аргумента в функции, либо из STDIN или эквивалентного
- Вывод может быть либо возвращаемым значением функции, либо распечатан в STDOUT или эквивалентный
- Вход будет содержать только цифры,
+
,*
, и новую строку\n
- На выходе должно быть только общее количество эльфов, от которых Санта нуждается в помощи для доставки на Рождество
- Применяются стандартные лазейки
счет
Сани Санты полны подарков, которые дают ему меньше места для выполнения кода, поэтому ему нужен самый короткий код, который он может получить (не волнуйтесь, если это не имеет смысла. Если вы сомневаетесь в логике Санты, вы окажетесь в списке непослушных ). Из-за ПРАВИЛЬНОГО рассуждения Санты выигрывает самое короткое представление в байтах!
Leaderboard
Это фрагмент стека, который генерирует как таблицу лидеров, так и обзор победителей по языкам.
Чтобы убедиться, что ваш ответ появляется, пожалуйста, начните свой ответ с заголовка, используя следующий шаблон уценки
## Language Name, N bytes
Где N - размер вашего сообщения в байтах
Если вы хотите включить в заголовок несколько чисел (например, пролистать старые оценки или включить флаги в счетчик байтов), просто убедитесь, что фактическая оценка является последней цифрой в заголовке.
## Language Name, <s>K</s> X + 2 = N bytes
max(naughty) + max(nice)
эльфов для всего маршрута? Я думал, что с ним летит кучка эльфов, но, возможно, у вас есть инсайдерская информация об этом, и мне нужно присмотреться в этом году. :)hello-world.c
. Рабочие эльфы охотно распределяются по целям, как сказал Джоджодмо (я уверен, что я знаю, что Джоджодмо, он должен быть нашим системным администратором), а затем используют функцию обратного вызова для уведомления, когда пора вставлять их в бассейн сани или когда ребенок их видел.Ответы:
Pyth, 21 байт
Многострочный пример
Однострочный набор тестов
источник
JavaScript (ES6), 52 байта
объяснение
Преобразует ввод в действительный оператор JavaScript. Заменяет все
*
на.0*3+
и все другие (не цифры) символы на.0*2+
. Например8*9+*10
становится8.0*3+9.0*2+.0*3+10
. Наконец он добавляется.0*2
в конец для последнего приятного счета. Это работает, потому чтоn.0
=n
и.0
=0
.Тест
Показать фрагмент кода
источник
.0
идею.Flex + C,
11290 байтПервый символ - это пробел. Компилировать с:
Читает из STDIN, пишет в STDOUT. Ввод завершается EOF (Ctrl + D в консоли).
источник
Mathematica, 70 байт
Используется
StringExtract
для извлечения отдельных номеров.источник
CJam, 23 байта
Проверьте это здесь.
объяснение
источник
Серьезно,
3830 байтШестнадцатеричный дамп:
Эта новая версия ломает онлайн-переводчика, но отлично работает локально. Вот пример запуска:
Объяснение:
Старая версия:
Шестнадцатеричный дамп:
Попробуйте онлайн
Объяснение:
Возможно, это могло бы быть короче, если бы я просто конвертировал каждую строку отдельно и суммировал их все в конце. Я посмотрю на это позже.
источник
PowerShell, 52 байта
Используя изменение user81655 «s
.0
трюкНеуправляемая версия
Пример использования
источник
Swift 2,
283211 байтЭто можно проверить на SwiftStub, здесь
Ungolfed
источник
Python 3,
141114112 байтПринимает многострочный ввод, как это
c("1*2+*+*4+1*\n2*4+3*+1*6+*\n*+*+4*2+1*1\n*4+*3+1*+2*3\n3*10+2*+*5+*")
Ungolfed:
источник
Я очень поздно, но я все равно хотел попробовать.
Рубин ,
8455 байтЯ снова нашел этот вопрос через столько лет и обдумывал новый ответ, прежде чем понял, что уже ответил на него раньше. Упс! В любом случае, вот резко улучшенный ответ.
Попробуйте онлайн!
Старый 84-байтовый ответ, когда я впервые ответил на это 2 года назад:
Попробуйте онлайн!
источник
Python 3 , 96 байт
Попробуйте онлайн!
101 байт без регулярных выражений
Попробуйте онлайн!
источник