Название фильма в стиле String

19

Вызов

Вы когда-нибудь видели названия трейлеров фильмов (а именно марсианские, межзвездные и т. Д.), Где между огромными буквами медленно растут огромные промежутки?

Задача состоит в том, чтобы воссоздать этот эффект с учетом строки, множителя и направления разрыва, вставив соответствующее количество пробелов между буквами.

пример

Ввод : «INTERSTELLAR», множитель разрыва: 1,0, направление: увеличение внутрь

Output: I N  T   E    R     S      T     E    L   L  A R

Интервал составляет: [1, 2, 3, ..., 3, 2, 1]; заменив пробелы на «.» чтобы лучше продемонстрировать интервал:

I.N..T...E....R.....S......T.....E....L...L..A.R

Ввод : «INTERSTELLAR», множитель разрыва: 0,5, направление: увеличение внутрь

Output: IN T E  R  S   T  E  L L AR

Интервал умножается на 0,5, поэтому мы получаем [0, 1, 1, 2, ... 2, 1, 1, 0] из целочисленного деления; с помощью '.':

IN.T.E..R..S...T..E..L.L.AR

Ввод : «CODEGOLF», множитель разрыва: 2.0, направление: увеличение наружу

Output: C        O      D    E  G    O      L        F

Интервал умножается на 2, увеличиваясь наружу, поэтому мы получаем [8,6,4,2,4,6,8]; заменить на '.':

C........O......D....E..G....O......L........F

Ввод : «CODEGOLF», множитель разрыва: 0,4, направление: увеличение наружу

Output: C O DEGO L F

Интервал умножается на 0,4, увеличиваясь наружу, поэтому получаем [1,1,0,0,0,1,1]; заменить на '.':

C.O.DEGO.L.F

правила

  • Принимает 3 входа: строка, множитель гэпа и направление
  • Если длина входной строки нечетная (даже в количестве пробелов), например, «HELLO», расстояние между двумя внутренними пробелами должно быть одинаковым H E L L O
  • Множитель направления и разрыва может быть проанализирован, как вы хотите, например, вы можете использовать -2 как «увеличение внутрь с множителем 2», 1 как «увеличение наружу с множителем 1» и т. Д.
  • Требуется использовать только пробелы, однако это бонус, если заполнение персонажа настраивается.

Справочная анимация

Ссылка GIF

Удачи в гольф!

Zukaberg
источник
1
Здравствуйте и добро пожаловать в PPCG! Вы могли бы хотеть сделать это немного проще, изменив Increasingк 1 => Inward, 0 => Outwardили наоборот.
NoOneIsHere
1
@NoOneIsHere Спасибо! Разбор направления и соотношения является гибким, согласно правилу 3, вы можете использовать 0,1, чтобы указать направление или даже объединить оба параметра в один, например, +4 для 4 внутрь, -0,5 для 0,5 снаружи и т. Д., Это просто нужно определить с решением.
Зукаберг
3
Это очень интересный вызов! Добро пожаловать на сайт. :)
DJMcMayhem
Я не понимаю, почему коэффициент разрыва 2 интерпретируется как растущий наружу, в то время как 1 и 0.5 оба растут внутрь.
xnor
@xnor ой, не извините за путаницу, направление не имеет отношения к отношению, направление и отношение - это отдельные параметры, 2.0 внутрь будет выглядеть так:C..O....D......E........G......O....L..F
Zukaberg

Ответы:

3

JavaScript (ES6), 86 82 81 80 байт

Ввод ожидается в синтаксисе карри f(s)(r)с:

  • s = строка
  • r = отношение + направление: отрицательное смещение для внутреннего или положительное смещение для внешнего

let f =

s=>r=>s.replace(/./g,(c,i)=>c+' '.repeat(n+=i<l?-r:r),l=s.length/2,n=r>0&&l*r+r)

console.log(f("INTERSTELLAR")(-1));
console.log(f("INTERSTELLAR")(-0.5));
console.log(f("CODEGOLF")(2));
console.log(f("CODEGOLF")(0.4));

Arnauld
источник
1

APL, 40 байт

{⍵\⍨0~⍨∊1,⍨1,¨-⌊⍺×(1+⌈/-+)⍣⍺⍺(⌽⌊+)⍳⍴1↓⍵}

Принимает строку в качестве правого аргумента, отношение в качестве левого аргумента и направление в качестве левого операнда (0 для внутреннего и 1 для внешнего).

      1 (0 {⍵\⍨0~⍨∊1,⍨1,¨-⌊⍺×(1+⌈/-+)⍣⍺⍺(⌽⌊+)⍳⍴1↓⍵}) 'INTERSTELLAR'
I N  T   E    R     S      T     E    L   L  A R
      0.5 (0 {⍵\⍨0~⍨∊1,⍨1,¨-⌊⍺×(1+⌈/-+)⍣⍺⍺(⌽⌊+)⍳⍴1↓⍵}) 'INTERSTELLAR'
IN T E  R  S   T  E  L L AR
      2 (1 {⍵\⍨0~⍨∊1,⍨1,¨-⌊⍺×(1+⌈/-+)⍣⍺⍺(⌽⌊+)⍳⍴1↓⍵}) 'CODEGOLF'
C        O      D    E  G    O      L        F
      0.4 (1 {⍵\⍨0~⍨∊1,⍨1,¨-⌊⍺×(1+⌈/-+)⍣⍺⍺(⌽⌊+)⍳⍴1↓⍵}) 'CODEGOLF'
C O DEGO L F

Объяснение:

  • ⍳⍴1↓⍵: получить список чисел от 1 до N-1, где N - длина строки
  • (⌽⌊+): инвертировать список, и в каждой позиции получить наименьшее количество обоих списков (это дает размеры пробелов при увеличении внутрь)
  • (1+⌈/-+)⍣⍺⍺: вычтите каждое число в списке из наибольшего числа в списке и добавьте 1. Сделайте это ⍺⍺раз. (Если ⍺⍺=0ничего не произойдет, и если ⍺⍺=1, это даст размеры зазоров при увеличении наружу.)
  • -⌊⍺×: умножьте каждый пробел на , округлите его вниз и сведите на нет.
  • ∊1,⍨1,¨: добавьте 1 перед каждым пробелом и 1 в самом конце списка.
  • 0~⍨: удалить все нули.
  • ⍵\⍨: использовать полученный список для расширения . Expand ( \) работает следующим образом: для каждого положительного числа текущий символ реплицируется столько раз, а для каждого отрицательного числа - сколько пробелов вставляется, с оговоркой, что 0и ¯1делают то же самое, поэтому все нули пришлось убрать раньше.
Мэринус
источник
1

MATL , 31 байт

nq:tPvX<i?tX>Qw-]*kQ1whYs''1Gb(

Входные данные: строка; 0или 1для внутреннего или внешнего увеличения; мультипликатор.

Попробуйте онлайн!

объяснение

Рассмотрим входы 'INTERSTELLAR', 1, в 0.5качестве примера.

nq:    % Input string implicitly. Push [1 2 ... N-1] where N is the string length
       %   STACK: [1 2 3 4 5 6 7 8 9 10 11]
tP     % Duplicate, reverse
       %   STACK: [1 2 3 4 5 6 7 8 9 10 11], [11 10 9 8 7 6 5 4 3 2 1]
vX<    % Vertically concatenate. Minimum of each column
       %   STACK: [1 2 3 4 5 6 5 4 3 2 1]
i      % Input direction flag
       %   STACK: [1 2 3 4 5 6 5 4 3 2 1], 1
?      % If input flag was 1 (meaning outward increasing)
  tX>  %   Duplicate. Maximum
       %     STACK: [1 2 3 4 5 6 5 4 3 2 1], 6
  Q    %   Add 1
       %     STACK: [1 2 3 4 5 6 5 4 3 2 1], 7
  w-   %   Swap. Subtract
       %     STACK: [6 5 4 3 2 1 2 3 4 5 6]
]      % End
*k     % Input multiplier implicitly. Multiply. Round down
       %   STACK: [3 2 2 1 1 0 1 1 2 2 3]
Q      % Add 1
       %   STACK: [4 3 3 2 2 1 2 2 3 3 4]
1wh    % Prepend a 1
       %   STACK: [1 4 3 3 2 2 1 2 2 3 3 4]
Ys     % Cumulative sum
       %   STACK: [1  5  8 11 13 15 16 18 20 23 26 30]
''     % Push empty string
       %   STACK: [1  5  8 11 13 15 16 18 20 23 26 30], ''
1G     % Push input string again
       %   STACK: [1  5  8 11 13 15 16 18 20 23 26 30], '', 'INTERSTELLAR'
b      % Bubble up
       %   STACK: '', 'INTERSTELLAR', [1  5  8 11 13 15 16 18 20 23 26 30]
(      % Assign the characters from the top string into the empty string at the 
       % given positions. Intermediate positions are filled with character 0, 
       % which is displayed as a space
       %   STACK: 'I   N  T  E R ST E L  L  A   R'
       % Dispaly implicitly
Луис Мендо
источник
1

Ракетка 348 байт

(define(f s)(let*((c #\space)(sp(λ(l)(define ol'())(for((i(length l)))(for((j i))
(set! ol(cons c ol)))(set! ol(cons(list-ref l i)ol)))(for((n(floor(/(length l)2))))
(set! ol(cons c ol)))ol))(m(floor(/(string-length s)2)))(s1(sp(string->list(substring s 0 m)
)))(s2(sp(reverse(string->list(substring s m))))))(list->string(append(reverse s1)s2))))

Ungolfed:

(define(f s)
  (let* ((c #\space)
         (sp (λ (l)           ; subfn to add increasing spaces to list of characters
               (define ol '())
               (for ((i (length l)))
                 (for ((j i))
                   (set! ol (cons c ol)))
                 (set! ol (cons (list-ref l i)ol)))
               (for ((n (floor(/ (length l)2)))) 
                 (set! ol (cons c ol)))
               ol))
         (m (floor (/ (string-length s) 2)))                 ; find midpoint
         (s1 (sp (string->list (substring s 0 m))))          ; add spaces to first part
         (s2 (sp (reverse (string->list (substring s m)))))) ; add spaces to second part
    (list->string (append (reverse s1) s2))                  ; re-combine 2 parts
    ))

Тестирование:

(f "INTERSTELLAR")

Выход:

"I N  T   E    R     S      T     E    L   L  A R"
rnso
источник
1

PHP, 129 байт

12 байтов сохранено @Titus Спасибо

строка = $ argv [1], отношение = $ argv [2], направление = $ argv [3] внутрь = 0, наружу = 1

for($i=0;$i+1<2*$l=strlen($t=($x=$argv)[1]);)echo$i%2?str_pad("",$x[2]*abs($x[3]*(0^$l/2+1)-($i++>=$l?$l-$i/2:$i/2))):$t[$i++/2];
Йорг Хюльсерманн
источник
str_padдолжен сохранить 4 байта. Попробуйте ++$i>$l?$l-$i/2:$i/2и $t[$i++]/2вместо приращения в пост-условии цикла; это должно спасти 9. Почему 0^?
Тит
0^3.12Результат @Titus, в 3котором необходимо
Йорг Хюльсерманн
$i=0не нужно ++$i>по- прежнему сохраняет один байт над $i++>=. И Вы можете сохранить еще один байт, переместив это приращение в предварительное условие: ++$i<2*$l=...вместо того $i+1<2*$l=..., чтобы поменять местами ветви истины и ложи внешней троицы, $iвместо ++$iи $t[$i/2-.5]вместо $t[$i++/2].
Тит
Определение внутрь as 1и out as 2позволит вам сохранить еще 3 байта: ($l>>1)вместо (0^$l/2+1); но я не проверял ничего из этого.
Тит
@ Таким образом, это приведет к увеличению пространства
Йорг Хюльсерманн,