Вступление:
(Источник: Википедия )
Когда мы смотрим на радугу, она всегда будет иметь цвета сверху вниз:
красный; апельсин; желтый; зеленый; синий; индиго; Фиолетовый
Если мы посмотрим на эти отдельные кольца, красное кольцо, конечно, больше, чем фиолетовое кольцо.
Кроме того, также возможно иметь две или даже три радуги одновременно.
Все это, вместе взятые, будет использовано в этой задаче:
Вызов:
Учитывая целое число n
, выведите столько колец из (возможно, более одного) «радуг», где мы будем использовать буквы vibgyor
для цветов.
См. Контрольные примеры ниже, чтобы увидеть, как они построены вверх n=1
и как следует обрабатывать интервалы (в n=8
). Как видите, между двумя радугами добавляется один пробел, включая расстояние сверху, прежде чем мы добавим кольцо следующей радуги в линию.
Правила вызова:
- Вам разрешено использовать заглавные
VIBGYOR
буквы вместо строчных - Между отдельными радугами должно быть пространство
- Допускается любое количество начальных и / или конечных пробелов / новых строк, если только правильная радуга (где бы она ни находилась на экране)
- На входе всегда будет положительное целое число (
>= 1
). Следовательно, поведение когдаn=0
не определено, и программа / функция может делать все что угодно (ничего не выводить; выводить радугуn=1
; случайный вывод; ошибка с ошибкой и т. Д.) - Вы можете вывести список / массив строк или двумерный массив / список символов, если хотите (вы можете добавить действительный код красивой печати в нижний колонтитул TIO).
- Не обращайте внимания на тот факт, что результаты больше похожи на храмы майя, чем на радугу. XD
Основные правила:
- Это код-гольф , поэтому выигрывает самый короткий ответ в байтах.
Не позволяйте языкам кода-гольфа отговаривать вас от публикации ответов на языках, не относящихся к кодексу. Попробуйте найти как можно более короткий ответ для «любого» языка программирования. - К вашему ответу применяются стандартные правила , поэтому вы можете использовать STDIN / STDOUT, функции / метод с правильными параметрами и типом возврата, полные программы. Ваш звонок.
- По умолчанию лазейки запрещены.
- Если возможно, добавьте ссылку с тестом для вашего кода.
- Кроме того, добавление объяснения для вашего ответа настоятельно рекомендуется.
Контрольные примеры (с первого n=1
по n=10
, и n=25
):
1:
vvv
v v
2:
iii
ivvvi
iv vi
3:
bbb
biiib
bivvvib
biv vib
4:
ggg
gbbbg
gbiiibg
gbivvvibg
gbiv vibg
5:
yyy
ygggy
ygbbbgy
ygbiiibgy
ygbivvvibgy
ygbiv vibgy
6:
ooo
oyyyo
oygggyo
oygbbbgyo
oygbiiibgyo
oygbivvvibgyo
oygbiv vibgyo
7:
rrr
rooor
royyyor
roygggyor
roygbbbgyor
roygbiiibgyor
roygbivvvibgyor
roygbiv vibgyor
8:
vvv
v v
v rrr v
v rooor v
v royyyor v
v roygggyor v
v roygbbbgyor v
v roygbiiibgyor v
v roygbivvvibgyor v
v roygbiv vibgyor v
9:
iii
ivvvi
iv vi
iv rrr vi
iv rooor vi
iv royyyor vi
iv roygggyor vi
iv roygbbbgyor vi
iv roygbiiibgyor vi
iv roygbivvvibgyor vi
iv roygbiv vibgyor vi
10:
bbb
biiib
bivvvib
biv vib
biv rrr vib
biv rooor vib
biv royyyor vib
biv roygggyor vib
biv roygbbbgyor vib
biv roygbiiibgyor vib
biv roygbivvvibgyor vib
biv roygbiv vibgyor vib
25:
ggg
gbbbg
gbiiibg
gbivvvibg
gbiv vibg
gbiv rrr vibg
gbiv rooor vibg
gbiv royyyor vibg
gbiv roygggyor vibg
gbiv roygbbbgyor vibg
gbiv roygbiiibgyor vibg
gbiv roygbivvvibgyor vibg
gbiv roygbiv vibgyor vibg
gbiv roygbiv rrr vibgyor vibg
gbiv roygbiv rooor vibgyor vibg
gbiv roygbiv royyyor vibgyor vibg
gbiv roygbiv roygggyor vibgyor vibg
gbiv roygbiv roygbbbgyor vibgyor vibg
gbiv roygbiv roygbiiibgyor vibgyor vibg
gbiv roygbiv roygbivvvibgyor vibgyor vibg
gbiv roygbiv roygbiv vibgyor vibgyor vibg
gbiv roygbiv roygbiv rrr vibgyor vibgyor vibg
gbiv roygbiv roygbiv rooor vibgyor vibgyor vibg
gbiv roygbiv roygbiv royyyor vibgyor vibgyor vibg
gbiv roygbiv roygbiv roygggyor vibgyor vibgyor vibg
gbiv roygbiv roygbiv roygbbbgyor vibgyor vibgyor vibg
gbiv roygbiv roygbiv roygbiiibgyor vibgyor vibgyor vibg
gbiv roygbiv roygbiv roygbivvvibgyor vibgyor vibgyor vibg
gbiv roygbiv roygbiv roygbiv vibgyor vibgyor vibgyor vibg
Ответы:
Python 2 ,
848281 байт-2 байта благодаря ElPedro.
Попробуйте онлайн!
источник
JavaScript (ES6), 100 байт
Возвращает массив строк.
Попробуйте онлайн!
источник
05AB1E ,
323123 байтаПопробуйте онлайн!
-1 благодаря Кевину Круйссену и -8 благодаря Аднану
Пояснение (Пример стека с вводом 3):
источник
"vibgyor"
может быть в гольф на 1 байт до.•2Bãθ(•
. ( Вот объяснение этому в разделе « Как сжимать строки, не являющиеся частью словаря? ».) Кроме того,„vr…v r:ð«
можно сыграть в гольф'v„v .:
. Итак, 28 байтов . Хороший ответ, хотя +1 от меня..••
не сохранит байт. Показывает, что один раз, когда я на самом деле не проверяю, это время, когда он будет сохранять байты xD. Хороший улов.•VvÈ©•¹∍¬„ v:Rηε¬ý}.c
¬ý
гениален ... Боже ... Ты так думаешь по-другому, и это круто.Холст ,
292826 байтПопробуй это здесь!
Объяснение:
252422 байта после фиксации того, что shouldold должен циклически изменяться, если требуемая длина больше, чем длина входных данных, и фиксируется/
примерно в 10 разисточник
v
боком (<
)? Является лиv
уже зарезервированное ключевое слово в Canvas, если так, почему бы не использовать<
вместо этого обратное ключевое слово?<
повернутые на 90 ° против часовой стрелки равныv
: P Все ASCII являются частью строк в Canvas, кстатиv
здесь, а затем поверните его на 90 градусов против часовой стрелки, он становится>
вместо этого. Понимаю. : DHaskell ,
114110101 байтСпасибо [nimi] [1] за -
413 байт!Попробуйте онлайн!
источник
Dyalog APL ,
413938 байтПопробуйте онлайн!
Аналогичный подход к другим:
A←⌈⎕×8÷7
находит высоту радуги (также ширину самой длинной «половины строки» влево / вправо от центра) и назначает ееA
для последующего использования, в то же время¨-⍳
просматривая значения 1..A, отрицая их, чтобы выбрать на правильной стороне при использовании с↑
.A⍴' vibgyor'
генерирует «половину строки» и⍵↑
выбирает подстроку правильной длины.(⌽,⊃,A↑⊢)
генерирует полную строку в обратном порядке (для этого требуется меньше символов), начиная с перевернутой половины строки (⌽
), затем центральный символ, взятый из начала строки в половину строки (⊃
), и, наконец, правостороннюю версию половины строки (A↑⊢
). Финал⌽
переворачивает строку в правильную ориентацию и↑
превращает вектор строк в двумерный массив.Изменить: -2 благодаря dzaima
Редактировать: -1 благодаря ngn
источник
⍕⍪
с↑
- вывода 2D массив символов разрешено1+÷7
->8÷7
Python 2 , 108 байт
Попробуйте онлайн!
источник
Древесный уголь , 30 байт
Попробуйте онлайн! Ссылка на подробную версию кода. Объяснение:
Измените направление рисования вверх.
Рассчитайте высоту радуги и повторите буквальную строку до этой длины.
Напечатайте центральную линию радуги.
Напечатайте правую половину радуги, взяв последовательные кусочки и напечатав каждый на отдельной «линии».
Подумайте, чтобы завершить радугу.
источник
Желе , 31 байт
Попробуйте онлайн!
Проверьте набор тестов!
ಠ_ಠ Это слишком сложно, потому что у желе нет функции централизации ...
источник
Желе , 28 байт
Монадическая ссылка, принимающая целое число, которое выдает список списков символов.
Попробуйте онлайн! (нижний колонтитул объединяется с символами новой строки)
Или посмотрите набор тестов .
Как?
источник
R , 130 байт
Попробуйте онлайн!
источник
Haskell , 106
113байтовЯ пока не могу комментировать другие сообщения (а именно это ), поэтому я должен опубликовать решение как отдельный ответ.
Гольф от 7 байтов от овс
Попробуйте онлайн!
( Старая версия , 113 байт)
источник
PowerShell ,
108988985 байтПопробуйте онлайн!
С этим сейчас все в порядке. Банковское округление - все еще дьявол, и я разобрался, как сделать не тупое соединение. Я попытался поиграть в обезьяны с небольшим успехом. Говоря о, результаты без объединений выглядят довольно хорошо, немного плавно:
источник
Python 2 ,
132131 байтПопробуйте онлайн!
Добавлено:
источник
//
в Python 2?Красный , 153 байта
Попробуйте онлайн!
Чуть более читабельно:
источник
Java (JDK 10) , 184 байта
Попробуйте онлайн!
Печатает дополнительный начальный и конечный пробел для каждого кратного 7.
объяснение
кредиты
источник
,w=-~h*2+1,i=h+1
на,i=h+1,w=i*2+1
i-~i
вместоi*2+1
Stax , 23 байта
Запустите и отладьте его
Распакованный, размазанный и прокомментированный, это выглядит так.
Запустите этот
источник