HexaGolf: Wordagons

25

Смотрите также: Ротатагон

Вызов

Учитывая строку в качестве входных данных, выведите ее wordagon.

Wordagons

Словоагон - это способ представления строки в шестиугольнике. Теперь давайте создадим слово из строки hexa:

Во-первых, вы начинаете с первого символа в строке и помещаете его в центр:

h

Затем вы берете следующий символ в строке и добавляете шестиугольный слой:

 e e
e h e
 e e

Затем добавьте следующий слой:

  x x x
 x e e x
x e h e x
 x e e x
  x x x

Наконец, добавьте последний слой:

   a a a a
  a x x x a
 a x e e x a
a x e h e x a
 a x e e x a
  a x x x a
   a a a a

И теперь у вас есть слово для строки hexa.

Примеры

Вот некоторые, которые я подготовил ранее:

hello

    o o o o o
   o l l l l o
  o l l l l l o
 o l l e e l l o
o l l e h e l l o
 o l l e e l l o
  o l l l l l o
   o l l l l o
    o o o o o

PPcg

   g g g g
  g c c c g
 g c P P c g
g c P P P c g
 g c P P c g
  g c c c g
   g g g g

o *

  * * *
 *     *
*   o   *
 *     *
  * * *

(T_T)

    ) ) ) ) )
   ) T T T T )
  ) T _ _ _ T )
 ) T _ T T _ T )
) T _ T ( T _ T )
 ) T _ T T _ T )
  ) T _ _ _ T )
   ) T T T T )
    ) ) ) ) )

Обратите внимание, что завершающие и / или ведущие новые строки разрешены.

выигрыш

Самый короткий код в байтах побеждает.

Бета распад
источник
14
Бонусные баллы, если кто-то делает это в гексагонии? ;)
Кевин Круйссен
Может ли входная строка содержать перевод строки? Я не думаю, что это создаст какие-либо проблемы с реализацией, просто создайте недействительные словагоны
Aaron
@ Аарон Нет, входная строка никогда не будет включать переводы строк
Beta Decay
это нормально, если на выходе получается строка с символами новой строки, возвращенными из функции?
Даниил
2
Оо. Я разочарован, потому что я прочитал название как «слово-драконы» ...
mbomb007

Ответы:

19

Python 2, 83 байта

s=input()
l=len(s)
while 1:l-=1;y=abs(l);print' '*y+' '.join(s[:y:-1]+s[y]*y+s[y:])

Печатает словогон, а затем вылетает (который печатает только в STDERR).

Пример:

% python2.7 wordagon.py <<<'"abcde"' 2&>/dev/null
    e e e e e
   e d d d d e
  e d c c c d e
 e d c b b c d e
e d c b a b c d e
 e d c b b c d e
  e d c c c d e
   e d d d d e
    e e e e e

xnor сэкономил 5 байтов. Благодарность!

Линн
источник
2
Элегантное решение.
DavidC
1
Вы можете пройтись по yним, завершив n=len(s)\nwhile 1:n-=1;y=abs(n);...работу с ошибкой.
xnor
10

Vim, 92 байта

:se ri|s/./ &/g
ⓋCⓇ"Ⓓ␛$vpmlmrqqYpi ␛`ljxxhmlylv`rjlmr:s/\%V\(.\)./Ⓡ" /g
@qq@qVdy2G:g/^/m0
Gp

Обведенные кружком буквы представляют Control+ букву; Escape это побег.

asciicast

Линн
источник
3
Не будет ли это считаться нажатием клавиш?
Сорен
1
@moo_we_all_do Нет. Это код-гольф (в отличие от редактора-гольфа), поэтому все ответы должны оцениваться в байтах.
Мартин Эндер
Второе @qвызывает бесконечный цикл для меня. Он отлично работает, если его убрать.
MTCoster
6

Mathematica 100 219 байт

Если ASCII-Art не обязательно должен быть Terminal-Art, это должно быть в силе.

Мое раннее представление по ошибке нарисовало звезду, а не шестиугольник. Я не вижу, как я был так выключен!

c = CirclePoints@6;
f@s_:=Graphics[{Text[s~StringPart~1,{0,0}],Flatten@Table[Text[StringPart[s,n+1],#]&/@Subdivide[Sequence@@#,n]&/@Partition[Riffle[(n)CirclePoints@6,RotateLeft[n CirclePoints@6]],2],{n,1,StringLength@s-1}]},BaseStyle->20]

CirclePoints@6 возвращает вершины единичного шестиугольника, предполагая, что центр находится в начале координат.

Subdivideкоординаты соседних вершин находят одинаково расположенные позиции вдоль соответствующего ребра.

Счетчик от 1 до StringLength -1входной строки позволяет обрабатывать каждый слой словагона отдельно.
По мере nувеличения увеличивается и расстояние до каждой вершины от начала координат.

Text[s~StringPart~1,{0,0}] печатает первую букву ввода в начале координат


е @ "Wordagon"

wordagon


Для любопытных, вот как выглядела звездная версия. Я знаю, это было далеко от цели. Он показывал только буквы в вершинах шестиугольника.

Graphics@Table[Text[Style[StringPart[#, r + 1], 54], r {Cos@t, Sin@t}], {t, 0, 2π, π/3}, {r, 0, StringLength@# - 1}] &["Hexa"]

гекса

DavidC
источник
5
Можете ли вы опубликовать, как выглядела звезда? : D
бета-распад
Конечно. Это теперь отправлено.
DavidC
2
Вау, это хорошая звезда
Beta Decay
3

Рубин, 82 байта

->s{n=s.size-1
(r=-n..n).map{|i|(" "*k=i.abs)+r.map{|j|s[[k+j,k,-j].max]}*" "}*$/}

перебирает 1-n..n-1в обоих направлениях i = y и j = x. Без начальных пробелов в каждой строке результат будет выглядеть, как показано ниже, в результате выбора символа из s индекса [[i.abs+j,i.abs,-j].max]. Добавление ведущих пробелов образует необходимый шестиугольник.

f f f f
f l l l f
f l o o l f
f l o G o l f
f l o o l f
f l l l f
f f f f

Неуправляемый в тестовой программе

f=->s{
  n=s.size-1             n=string length - 1
  (r=-n..n).map{|i|      iterate from -n to n, build an array of lines
    (" "*k=i.abs)+       k=i.abs. Start each line with k spaces.
    r.map{|j|            iterate from -n to n, build an array of characters.
      s[[k+j,k,-j].max]  select character from s (store null string in array if index past end of string)
    }*" "                concatenate the array of characters into a line, separated by spaces
  }*$/                   concatenate the array of lines into a single string, separate by newlines
}

puts f[gets.chomp]

Типичный вывод

   f f f f
  f l l l f
 f l o o l f
f l o G o l f
 f l o o l f
  f l l l f
   f f f f
Уровень реки St
источник
3

JavaScript (ES6), 118 байт

s=>[...Array((l=s.length-1)*2+1)].map((_,i,a)=>a.map((_,j)=>s[Math.max(i-l,l-i,j-l,i-j,l+l-i-j)]||``).join` `).join`\n`

Где \nпредставляет буквальный символ новой строки. На основании моего ответа на вызов Hexplosive ASCII-art, хотя части решения напоминают ответ Ruby от @ LevelRiverSt. Различные компоненты Math.maxпроизводят следующую продукцию для l=3:

    i - l           l - i           j - l            i - j        l + l - i - j
- - - - - - -   3 3 3 3 3 3 3   - - - 0 1 2 3    0 - - - - - -    6 5 4 3 2 1 0
- - - - - - -   2 2 2 2 2 2 2   - - - 0 1 2 3    1 0 - - - - -    5 4 3 2 1 0 -
- - - - - - -   1 1 1 1 1 1 1   - - - 0 1 2 3    2 1 0 - - - -    4 3 2 1 0 - -
0 0 0 0 0 0 0   0 0 0 0 0 0 0   - - - 0 1 2 3    3 2 1 0 - - -    3 2 1 0 - - -
1 1 1 1 1 1 1   - - - - - - -   - - - 0 1 2 3    4 3 2 1 0 - -    2 1 0 - - - -
2 2 2 2 2 2 2   - - - - - - -   - - - 0 1 2 3    5 4 3 2 1 0 -    1 0 - - - - -
3 3 3 3 3 3 3   - - - - - - -   - - - 0 1 2 3    6 5 4 3 2 1 0    0 - - - - - -

Максимальное значение берется, а значения больше, чем lудаляются, создавая таким образом форму шестиугольника, а остальные значения отображаются в символы из строки:

6 5 4 3 3 3 3      3 3 3 3          a a a a
5 4 3 2 2 2 3     3 2 2 2 3        a x x x a
4 3 2 1 1 2 3    3 2 1 1 2 3      a x e e x a
3 2 1 0 1 2 3   3 2 1 0 1 2 3    a x e h e x a
4 3 2 1 1 2 3    3 2 1 1 2 3      a x e e x a
5 4 3 2 2 2 3     3 2 2 2 3        a x x x a
6 5 4 3 3 3 3      3 3 3 3          a a a a
Нил
источник
1

05AB1E , 31 байт

R.pvy`¹gN-©×NFs.ø}Sðý®ð×ì})¦«»

объяснение

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

R.pv                     }       # for each prefix of the reversed string
                                 # ['f', 'fl', 'flo', 'floG']
    y`                           # split into chars, ex: 'f', 'l', 'o'
      ¹gN-©×                     # repeat the last char len(input)-N times, 
                                 # where N is the 0-based list index of the current prefix
                                 # ex: 'oo'
            NF   }               # N times do
              s.ø                # surround current char with the next char on stack
                                 # ex: 'floolf'
                  Sðý            # insert spaces between each letter, ex: 'f l o o l f'
                     ®ð×ì        # prefix string with len(input)-N spaces
                                 # ex: '  f l o o l f'
                          )      # wrap all strings in a list
                           ¦    # create a reversed copy of the list and 
                                 # remove the first item (as we only need the middle once)
                             «»  # concatenate the lists and merge with newlines

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

Emigna
источник
0

Python 2, 104 байта

def f(s):
 for n in range(len(s)*2-1):x=abs(n-len(s)+1);print' '*x+' '.join(s[x+1:][::-1]+s[x]*x+s[x:])
Даниил
источник
0

PHP - 202 байта

$w=$argv[1];$l=$i=$a=strlen($w)-1;while(-$l<=$i){$s=join(" ",str_split(str_repeat($w[$l],($a-1)/2).substr($w,$a?$a:1,$l+1),1));echo str_pad("",$a).strrev($s).($a%2?" ":" {$w[$a]} ")."$s
";$a=abs(--$i);}

Использование из командной строки:

php.exe -r "put the escaped code here" "put your desired word here"

например:

php.exe -r "$w=$argv[1];$l=$i=$a=strlen($w)-1;while(-$l<=$i){$s=join(\" \",str_split(str_repeat($w[$l],($a-1)/2).substr($w,$a?$a:1,$l+1),1));echo str_pad(\"\",$a).strrev($s).($a%2?\" \":\" {$w[$a]} \").\"$s\n\";$a=abs(--$i);}" "example"

Тестовый пакет .

п-х
источник