Печать Волнистой Строки Line-Line

23

Вызов

Напишите программу или функцию, которая принимает строку sи целое число в nкачестве параметров. Ваша программа должна напечатать (или вернуть) строку при преобразовании следующим образом:

Начиная сверху слева и двигаясь вниз и вправо, пишите sкак волна высоты n. Затем сверху вниз объедините каждую строку в строку (без пробелов).

пример

Дана строка "WATERMELON" и высота 3:

Волна должна выглядеть так:

W   R   O
 A E M L N
  T   E

Затем объедините строки сверху вниз:

WRO
AEMLN
TE

Итак, ваша программа должна вернуть строку "WROAEMLNTE"

Аналогично, "WATERMELON" с высотой 4 должен произвести следующую волну:

W     E
 A   M L
  T R   O
   E     N

Ваша программа должна затем вернуть строку "WEAMLTROEN"

правила

вход

Входные данные могут быть приняты в любом разумном формате. Строка может быть в любом случае вы предпочитаете. Вы можете предположить, что0 < n <= s.length

Выход

Вывод должен состоять только из преобразованной строки (независимо от того, возвращена она или напечатана в STDOUT), плюс любые завершающие символы новой строки.

счет

Это , поэтому выигрывает самый короткий ответ в байтах! Стандартные лазейки не допускаются.

Тестовые случаи

Input                        Output

programmingpuzzles, 5 ->     piermnlsomgzgapzru
codegolf, 3           ->     cgoeofdl
elephant, 4           ->     enlatehp
1234567, 3            ->     1524637
qwertyuiop, 1         ->     qwertyuiop
Cowabunghole
источник
Можем ли мы предположить n> 1? Пожалуйста, уточните, а если нет, добавьте тестовый пример
Луис Мендо,
1
Вы можете предположить n > 0, но n=1это действительный случай. Я обновлю вопрос сейчас.
Cowabunghole
2
@ Яблочная дыра, которую я знаю. :) «Только связанный» означает, что это несколько похоже, и существующие ответы могут быть полезны для этой задачи. Я только упомянул это, чтобы они появились в связанных вопросах справа. Связано! = Дублируется. ;)
Кевин Круйссен
5
Я никогда не видел шифр ограждения, кодируемый только одним рельсом. Просто
говорю
1
@Veskah Ах да, старый трюк с двойным рот13.
wooshinyobject

Ответы:

5

Шелуха , 6 байт

δÖK…¢ḣ

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

Работает n = 1также.

объяснение

δÖK…¢ḣ  Implicit inputs, say n=4 and s="WATERMELON"
     ḣ  Range: [1,2,3,4]
    ¢   Cycle: [1,2,3,4,1,2,3,4,1,2,3,4..
   …    Rangify: [1,2,3,4,3,2,1,2,3,4,3,2..
δÖK     Sort s by this list: "WEAMLTROEN"
        Print implicitly.

Функция высшего порядка δработает так под капотом. Предположим, у вас есть функция более высокого порядка, которая принимает унарную функцию и список и возвращает новый список. Например, Öберет функцию и сортирует список, используя ее в качестве ключа. Затем δÖпринимает бинарную функцию и два списка, объединяет их вместе, применяет Öдля сортировки пар, используя двоичную функцию в качестве ключа, и, наконец, проецирует пары во вторую координату. Мы используем Kв качестве ключевой функции, которая просто возвращает свой первый аргумент и игнорирует второй.

Zgarb
источник
6

MATL , 16 байт

Zv3L)t?yn:)2$S}i

Попробуйте онлайн! Или проверьте все тестовые случаи .

объяснение

Рассмотрим входы 5, 'programmingpuzzles'.

Zv     % Input, implicit: number n. Symmetric range
       % STACK: [1 2 3 4 5 4 3 2 1]
3L     % Push [1 -1+1j]. When used as an index, this means 1:end-1
       % STACK: [1 2 3 4 5 4 3 2 1], [1 -1+1j]
)      % Index. Removes last element
       % STACK: [1 2 3 4 5 4 3 2]
t      % Duplicate
       % STACK: [1 2 3 4 5 4 3 2], [1 2 3 4 5 4 3 2]
?      %   If non-empty and non-zero
       %   STACK: [1 2 3 4 5 4 3 2]
  y    %   Implict input: string s. Duplicate from below
       %   STACK: 'programmingpuzzles', [1 2 3 4 5 4 3 2], 'programmingpuzzles'
  n    %   Number of elements
       %   STACK: 'programmingpuzzles', [1 2 3 4 5 4 3 2], 18
  :    %   Range
       %   STACK: 'programmingpuzzles', [1 2 3 4 5 4 3 2], [1 2 3 ··· 17 18]
  )    %   Index modularly
       %   STACK: 'programmingpuzzles', [1 2 3 4 5 4 3 2 1 2 3 4 5 4 3 2 1 2]
  2$S  %   Two-input sort: stably sorts first input as given by the second
       %   STACK: 'piermnlsomgzgapzru'
}      % Else. This branch is entered when n=1. The stack contains an empty array
       %   STACK: []
  i    %   Take input
       %   STACK: [], [], 'programmingpuzzles'
       % End, implicit
       % Display stack, implicit. Empty arrays are not displayed
Луис Мендо
источник
5

J , 54, 29, 27 26 байтов

-1 байт благодаря hoosierEE

([\:#@[$[:}:|@i:@<:@]) ::[

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

Гален Иванов
источник
@ LuisMendo Хм, еще раз я пропустил что-то важное. Благодарность! Исправлена.
Гален Иванов
1
Я сначала тоже это пропустил, потом понял и спросил ОП. Должен был быть тестовый случай с n=1самого начала
Луис Мендо
1
|@i:вместо того, чтобы [:|i:сохранить байт
hoosierEE
@hoosierEE Да, спасибо!
Гален Иванов
5

R , 68 байт

function(s,n)intToUtf8(unlist(split(utf8ToInt(s),-(n:(2.9-n)-1)^2)))

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

  • -10 байт благодаря @Giuseppe
  • -17 байт, потому что я был глуп
  • -9 байт и n=1регистр исправлен благодаря @ J.Doe
  • -3 байта благодаря @JayCe
digEmAll
источник
3

05AB1E (наследие) , 11 8 байтов

Σ²Lû¨¾è¼

Вдохновлен ответом @LuisMendo на MATL .
-3 байта благодаря @Adnan, потому что я идиот ..>.>

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

Объяснение:

Σ           # Sort the (implicit) input-string by:
 ²L         #  Create a list in the range [1, second input-integer]
            #   i.e. 5 → [1,2,3,4,5]
   û        #  Palindromize it
            #   i.e. [1,2,3,4,5] → [1,2,3,4,5,4,3,2,1]
    ¨       #  Remove the last item
            #   i.e. [1,2,3,4,5,4,3,2,1] → [1,2,3,4,5,4,3,2]
     ¾è     #  Index into it (with wraparound) using the counter_variable (default 0)
            #   i.e. counter_variable = 0 → 1
            #   i.e. counter_variable = 13 → 4
       ¼    #  And after every iteration, increase the counter_variable by 1

ПРИМЕЧАНИЕ. counter_variableИспользуется, поскольку в версии 05AB1E для Python Legacy Σне было встроенного индекса N, как в новой версии 05AB1E для перезаписи Elixir. Так почему я до сих пор использую версию Legacy? Потому что в переписываемом Elixir он неявно преобразует строку в список символов, требуя дополнительного }Jпреобразования его обратно в строку для вывода (и он также содержит ошибку сейчас, когда èвообще не работает для индексации в удлиненный список ..: S)

Кевин Круйссен
источник
Вам не нужна ¹g∍деталь, так как 05AB1E использует циклическое индексирование для è.
Аднан
@Adnan Ах, я идиот ..>.> Спасибо!
Кевин Круйссен
2

Japt , 16 байт

¬üÏu´VÑ aV°ÃÔc q

Проверьте это онлайн!

объяснение

 ¬ üÏ   u´ VÑ  aV° Ã Ô c q
Uq üXY{Yu--V*2 aV++} w c q    Ungolfed
                               Implicit: U = input string, V = size of wave
Uq                             Split U into chars.
   üXY{            }           Group the items in U by the following key function:
       Y                         Take the index of the item.
        u--V*2                   Find its value modulo (V-1) * 2.
               aV++              Take the absolute difference between this and (V-1).
                                 This maps e.g. indices [0,1,2,3,4,5,6,7,...] with V=3 to
                                                        [2,1,0,1,2,1,0,1,...]
                                 The items are then grouped by these values, leading to
                                 [[2,6,...],[1,3,5,7,...],[0,4,...]].
                     w         Reverse the result, giving [[0,4,...],[1,3,5,7,...],[2,6,...]].
                       c       Flatten.
                         q     Join back into a single string.
ETHproductions
источник
oO этот üметод новый?
Луис Фелипе Де Иисус Муньос,
Да, добавил в субботу :-)
ETHproductions
Вы можете взять ввод как массив символов для сохранения байта и вывести один или использовать -Pфлаг для сохранения другого 2.
Shaggy
2

Желе , 8 байт

6 байт не подходит для высоты 1; два байта используются для его решения ... может быть 7 можно найти?

ŒḄṖȯ1ṁỤị

Двоичная ссылка, принимающая положительное целое число и список символов, который выдает список символов.

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

Как?

ŒḄṖȯ1ṁỤị - Link: positive integer N; list of characters, T
ŒḄ       - bounce (implicit range of) N -> [1,2,3,...,N-1,N,N-1,...,3,2,1]
  Ṗ      - pop off the final entry         [1,2,3,...,N-1,N,N-1,...,3,2]
   ȯ1    - OR one                          if this is [] get 1 instead
     ṁ   - mould like T (trim or repeat to make this list the same length as T)
      Ụ  - grade-up (get indices ordered by value - e.g. [1,2,3,2,1,2] -> [1,5,2,4,6,3])
       ị - index into T
Джонатан Аллан
источник
2

JavaScript (ES6), 75 байт

Более короткая формула, предложенная @MattH (-3 байта)

Принимает вход как (string)(n).

s=>n=>--n?[...s].map((c,x)=>o[x=x/n&1?n-x%n:x%n]=[o[x]]+c,o=[])&&o.join``:s

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


JavaScript (ES7), 78 байт

Сохранено 4 байта благодаря @ETHproductions

Принимает вход как (string)(n).

s=>n=>--n?[...s].map((c,x)=>o[x=n*n-(x%(n*2)-n)**2]=[o[x]]+c,o=[])&&o.join``:s

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

Arnauld
источник
Мое решение оказалось очень похожим на ваше. Вы можете сохранить -3 байт расчета индекса вставки из oс x/n&1?n-x%n:x%nвместо n*n-(x%(n*2)-n)**2.
MattH
@MattH Отлично сделано. Благодарность!
Арно
1

MBASIC , 146 159 155 байтов

1 INPUT S$,N:DIM C$(N):P=1:D=1:FOR I=1 TO LEN(S$):C$(P)=C$(P)+MID$(S$,I,1)
2 IF N>1 THEN P=P+D
3 IF P=N OR P=1 THEN D=-D
4 NEXT:FOR I=1 TO N:PRINT C$(I);:NEXT

Обновлено для обработки n = 1

Выход:

? programmingpuzzles, 5
piermnlsomgzgapzru

? codegolf, 3
cgoeofdl

? elephant, 4
enlatehp

? 1234567, 3
1524637

? WATERMELON, 4
WEAMLTROEN

? qwertyuiop, 1
qwertyuiop
wooshinyobject
источник
В настоящее время не поддерживается случай n = 1.
wooshinyobject
Обновлен для обработки случая n = 1
wooshinyobject
Сохранено 4 байта путем очистки сравнений.
wooshinyobject
1

Perl 6 , 49 байт

->\n{*.comb.sort({-abs n-1-$++%(2*n-2||1)}).join}

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

Принимает ввод как карри функцию.

Объяснение:

->\n{*.comb.sort({-abs n-1-$++%(2*n-2||1)}).join}
->\n{                                           }  # Take an number
     *.comb        # Turn the string into a list of chars
           .sort({                       })   # And sort them by
                           $++    # The index of the char
                              %(2*n-2||1)  # Moduloed by 2*(n-1) or 1 if n is 0
                       n-1-       # Subtract that from n-1
                   abs            # get the absolute value
                  -               # And negate to reverse the list
                                          .join  # and join the characters

Последовательность сортировки выглядит следующим образом (для n=5):

(-4 -3 -2 -1 0 -1 -2 -3 -4 -3 -2 -1 0 -1 -2 -3 -4 -3 -2 -1)
Джо Кинг
источник
1

J , 24 байта

4 :'x\:(#x)$}:|i:<:y'::[

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

Явный двоичный глагол. Запустите это как 'codegolf' f 3.

Как это работает

4 :'x\:(#x)$}:|i:<:y'::[    x: string, y: height
4 :                         Define a dyadic verb:
               i:<:y        Generate a range of -(y-1) .. y-1
            }:|             Take absolute value and remove last
       (#x)$             1) Repeat to match the string's length
    x\:                     Sort x by the decreasing order of above
                     ::[    If 1) causes `Length Error`, return the input string instead

Обычно явная функция занимает дополнительные 5 байтов в виде n :'...'. Но если добавляется обработка ошибок, разница уменьшается до 2 байтов из-за паренов и пробела в (tacit)<space>::.

фонтанчик для питья
источник
Почему я всегда склонен использовать sort up?! Ваш явный глагол по-прежнему на 3 байта короче. Хорошее решение!
Гален Иванов
1

Powershell, 99 95 байт

param($s,$n)$r=,''*$n
$s|% t*y|%{$r[((1..$n+$n..1)*$s.Length|gu)[$i++*($n-gt1)]-1]+=$_}
-join$r

Тестовый скрипт:

$f = {

param($s,$n)$r=,''*$n
$s|% t*y|%{$r[((1..$n+$n..1)*$s.Length|gu)[$i++*($n-gt1)]-1]+=$_}
-join$r

}

@(
    ,("1234567", 3            ,     "1524637")
    ,("qwertyuiop", 1         ,     "qwertyuiop")
    ,("codegolf", 3           ,     "cgoeofdl")
    ,("elephant", 4           ,     "enlatehp")
    ,("programmingpuzzles", 5 ,     "piermnlsomgzgapzru")
) | % {
    $s,$n,$e = $_
    $r = &$f $s $n
    "$($r-eq$e): $r"
}

Выход:

True: 1524637
True: qwertyuiop
True: cgoeofdl
True: enlatehp
True: piermnlsomgzgapzru

объяснение

Сценарий:

  • создает массив строк,
  • заполняет строки соответствующими значениями,
  • и возвращает соединенные строки.

Выражение ((1..$n+$n..1)*$s.Length|gu генерирует подобную последовательность 1,2,3,3,2,1,1,2,3,3,2,1... и удаляет соседние дубликаты. guэто псевдоним для Get-Unique .

  • Для $n=3дедуплицированной последовательности есть:1,2,3,2,1,2,3,2,1...
  • Для $n=1дедуплицированной последовательности есть:1

Выражение $i++*($n-gt1) возвращает индекс в дедуплицированной последовательности. =$i++если $n>1иначе=0

Mazzy
источник
1

Рубин , 75 65 байт

->s,h{a=['']*h;x=-k=1;s.map{|c|a[x+=k=h-x<2?-1:x<1?1:k]+=c};a*''}

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

Принимает ввод как массив символов, возвращает строку

Как это работает

  • Создайте h строки
  • Для каждого символа входной строки решите, в какую строку его поместить, основываясь на его индексе (индекс изменяемой строки увеличивается до, hа затем - до0 и т. Д.)
  • Вернуть все строки, соединенные вместе
Асоне Тухид
источник
@ GB это не работает в последнем случае
Asone Tuhid
1

C 142 134 байта

8 байтов сэкономлено благодаря Джонатану Фреху

Код:

t;i;j;d;f(s,n)char*s;{for(t=strlen(s),i=0;i<n;i++)for(j=0;j+i<t;j=d+i+(n<2))d=j-i+2*~-n,putchar(s[i+j]),i>0&i<n-1&d<t&&putchar(s[d]);}

Объяснение:

// C variable and function declaration magic
t;i;j;d;f(s,n)char*s;{
    // Iterate through each "row" of the string
    for(t=strlen(s),i=0;i<n;i++)
        // Iterate through each element on the row
        // Original index iterator here was j+=2*(n-1), which is a full "zig-zag" forward
        // The (n<2) is for the edge case of n==1, which will break the existing logic.
        for(j=0; j+i<t; j=d+i+(n<2))
            // If j+i is the "zig", d is the "zag": Original index was d=j+i+2*(n-i-1)
            // Two's complement swag here courtesy of Jonathan Frech
            d=j-i+2*~-n,
            putchar(s[i+j]),
            // Short circuit logic to write the "zag" character for the middle rows
            i>0 & i<n-1 & d<t && putchar(s[d]);
}

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

Й. Кноблаух
источник
1
Привет и добро пожаловать в PPCG; хороший первый гольф. 134 байта (при условии GCC).
Джонатан Фрех
0

Древесный уголь , 21 байт

⭆NΦη¬⌊E²﹪⁺μ⎇νι±ι∨⊗⊖θ¹

мям±язнак равно0(модификация2N-2)

 N                      First input as a number
⭆                       Map over implicit range and join
   η                    Second input
  Φ                     Filter over characters
       ²                Literal 2
      E                 Map over implicit range
          μ             Character index
             ι ι        Outer index
              ±         Negate
            ν           Inner index
           ⎇            Ternary
         ⁺              Plus
                   θ    First input
                  ⊖     Decremented
                 ⊗      Doubled
                    ¹   Literal 1
                ∨       Logical Or
        ﹪               Modulo
     ⌊                  Minimum
    ¬                   Logical Not
                        Implicitly print
Нил
источник
0

СНОБОЛ4 (CSNOBOL4) , 191 байт

	S =INPUT
	N =INPUT
	A =ARRAY(N)
	A<1> =EQ(N,1) S	:S(O)
I	I =I + -1 ^ D
	S LEN(1) . X REM . S	:F(O)
	A<I> =A<I> X
	D =EQ(I,N) 1
	D =EQ(I * D,1)	:(I)
O	Y =Y + 1
	O =O A<Y>	:S(O)
	OUTPUT =O
END

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

Берет SтогдаN по отдельным строкам.

Объяснение:

	S =INPUT			;* read S
	N =INPUT			;* read N
	A =ARRAY(N)			;* create array of size N
	A<1> =EQ(N,1) S	:S(O)		;* if N = 1, set A<1> to S and jump to O
I	I =I + -1 ^ D			;* index into I by I + (-1)^D (D starts as '' == 0)
	S LEN(1) . X REM . S	:F(O)	;* extract the first character as X and set S to the
					;* remaining characters, jumping to O when S is empty
	A<I> =A<I> X			;* set A<I> to A<I> concatenated with X
	D =EQ(I,N) 1			;* if I == N, D=1
	D =EQ(I * D,1)	:(I)		;* if I == D == 1, D = 0. Goto I
O	Y =Y + 1			;* increment the counter
	O =O A<Y>	:S(O)		;* concatenate the array contents until last cell
	OUTPUT =O			;* and print
END
Giuseppe
источник
0

Pyth , 22 21 байт

|seMhD,V*lz+PUQP_UQzz

Принимает ввод, а nзатем sв отдельных строках. Попробуйте онлайн здесь или проверьте все тестовые примеры сразу здесь .

|seMhD,V*lz+PUQP_UQzz   Implicit: Q=eval(input()), z=remaining input

             UQ         Range [0-Q)
            P           All but last from the above
                         e.g. for Q=3, yields [0,1]
               P_UQ     All but last of reversed range
                         e.g. for Q=3, yields [2,1]
           +            Concatenate the previous two results
                          e.g. for Q=3, yields [0,1,2,1]
        *lz              Repeat len(z) times
      ,V           z    Vectorised pair the above with z, truncating longer to length of shorter
                          e.g. for Q=3, z=WATERMELON, yields:
                          [[0,'W'],[1,'A'],[2,'T'],[1,'E'],[0,'R'],[1,'M'],[2,'E'],[1,'L'],[0,'O'],[1,'N']]
    hD                  Sort the above by the first element
                          Note this is a stable sort, so relative ordering between equal keys is preserved
  eM                    Take the last element of each
 s                      Concatenate into string
                          Note that if n=1, the result of the above will be 0 (sum of empty array)
|                   z   If result of above is falsey, yield z instead

Редактировать: сохранил байт, переместив пустой чек в конец обработки. Предыдущая версия: seMhD,V*lz|+PUQP_UQ]0z

Sok
источник
0

Красный , 153 байта

func[s n][i: v: m: 1 b: collect[foreach c s[keep/only reduce[v i c]v: v + m
if all[n > 1(i: i + 1)%(n - 1)= 1][m: -1 * m]]]foreach k sort b[prin last k]]

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

Объяснение:

f: func [ s n ] [                      ; s is the string, n is the height
    i: 1                               ; index of the current character in the string
    v: 1                               ; value of the "ladder"
    m: 1                               ; step (1 or -1)
    b: collect [                       ; collect the values in a block b
        foreach c s [                  ; foreach character in the string 
            keep/only reduce [ v i c ] ; keep a block of the evaluated [value index char] 
            i: i + 1                   ; increase the index
            v: v + m                   ; calculate the value 
            if all [ n > 1             ; if height is greater than 1 and
                    i % (n - 1) = 1    ; we are at a pick/bottom of the ladder
                   ]
                [ m: -1 * m ]          ; reverse the step
        ]
    ]
    foreach k sort b [ prin last k ]   ; print the characters in the sorted block of blocks
]
Гален Иванов
источник
0

У меня есть два решения проблемы. Первое решение, которое я сделал первым, затем я подумал о другом способе сделать это, который, как я думал, сэкономит байты, но это не так, я все равно включил его.


Решение 1

PHP , 152 144 116 байт

<?php
for($i=0;$i<$n=$argv[2];$i++)
    for($j=$i;$s=$argv[1][$j];$j+=$n<2|(($f=!$f|!$i)?$i<$n-1?$n+~$i:$i:$i)*2)
        echo $s;
  • 8 байтов благодаря @JoKing
  • 28 байтов благодаря @Shaggy

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


Решение 2

PHP , 162 байта

<?php
$s=$argv[0];
$n=$argv[1];
$l=strlen($s);
for($i=0;$i<$l;){
    for($j=0;$j<$n&&$i<$l;)
        $a[$j++].=$s[$i++];
    for($j=$n-2;$j>0&&$i<$l;)
        $a[$j--].=$s[$i++];
}
echo join($a);

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

Mic1780
источник
Вам не нужно инициализировать $fи $n-1-$iможет быть $n-~$i. 144 байта
Джо Кинг
-28 байт на улучшения @ JoKing.
лохматый
Oop; что ломается когда n=1. Этот работает для того же количества байтов.
Лохматый
Вы также можете использовать короткие теги и убрать пробел после того, echoкак сохранили еще 5 байтов
Shaggy