Зачерпніть мені морозиво, будь ласка


13

Зробіть мені конус із морозивом, будь ласка

У нас в Тоні, в Новій Англії, є чудове місце для морозива. Більшість із них зараз закриті на зиму, тому ...

   .-@@-.
  (======)
 (--------)
(==========)
(__________)
 \/\/\/\/\/
  \/\/\/\/
   \/\/\/
    \/\/
     \/

МЕТА Цілком виведіть вищевказану конус з морозивом. (або повернути його з функції)

Це код гольфу, тому найкоротша відповідь виграє


Це здається дивним викликом, чи не було б просто виконати те, що як рядковий буквальний технічно є рішенням для деяких інтерпретованих мов, таких як JS / Python?
Яків Персі

2
@JacobPersi Це класичний виклик складності колмогорів , де мета - максимально стиснути задану струну, жорстке кодування, ймовірно, не надто гофроване
Містер Xcoder

6
@MichaelDorgan багато мов було винайдено для коду гольфу, але це не повинно перешкодити вам відповідати на виробничих мовах - тут пропонується отримати цікаві відповіді, і відповідь iCeCrEaMCoNeне була б однією з таких. На цьому веб-сайті навіть існувало правило, на яке ви не можете відповісти мовою (/ використовувати функцію), новішою, ніж виклик, але його замінили на "не вимагайте тривіальних відповідей". Зрештою, ці мови для гольфу існують просто заради забави :)
dzaima

3
Зрозумів. Я нещодавно відповів на Arm Assembler. Очевидно, що не збирається перемагати, але все ж весело :)
Michael Dorgan

Відповіді:


10

SOGL V0.12 , 24 байти

u%⅝⁾⁷‰┘Η:⅛6s⁹№K⌠RΝīL°‘§╬

Спробуйте тут!

Просте рішення стиснення:

....‘    push "@-.¶===(¶----(¶=====(¶_____(¶\/\/\¶/\/\¶\/\¶/\¶\"
     §   pad with spaces and reverse horizontally
      ╬  palindromize with 0 overlap and mirroring the characters

Немає версії стиснення - набагато довше, оскільки для цього стиснення SOGL добре працює



8

PowerShell , 85 байт

"   .-@@-.
  (======)
 (--------)
($('='*10))
($('_'*10))"
1..5|%{" "*$_+'\/'*(6-$_)}

Спробуйте в Інтернеті!

АБО

PowerShell , 85 байт

"   .-@@-.
  (======)
 (--------)"
'=','_'|%{"($($_*10))"}
1..5|%{" "*$_+'\/'*(6-$_)}

Спробуйте в Інтернеті!

Візьміть свій вибір. В обох випадках у перших трьох рядках недостатньо байтів, щоб зробити якесь стиснення в PowerShell.

Перший випадок використовує множення рядків для отримання кожної з 10 довжини =та _рядків, а другий використовує множення циклу та рядків. В будь-якому випадку останній рядок утворює конус, циклічно переходячи 1до 5кожної ітерації, виводячи відповідну кількість пробілів, а потім відповідне число шматочків конуса.

Усі ці рядки залишаються на конвеєрі, і неявна Write-Outputпри завершенні програми дає нам нову лінію між елементами безкоштовно.



7

Вугілля деревне , 29 байт

@-.⸿E=-=⁺×ι⁺³κ)×_⁵P↙⁶)⸿‖M←¤/\

Спробуйте в Інтернеті! Посилання на багатослівну версію коду. Пояснення:

@-.⸿

Надрукуйте праву половину першого рядка.

E=-=⁺×ι⁺³κ)

Для кожного з символів =-=повторіть 3 рази на перший та додатковий час для кожного наступного символу, а потім додайте ), друкуючи кожен результат у власному рядку.

×_⁵

Друк 5 _с.

P↙⁶

Роздрукуйте край конуса.

)⸿

Надрукуйте остаточний )і розташуйте курсор всередині конуса.

‖M←

Дзеркало напівконуса.

¤/\

Наповніть тіло конуса.


7

Python 2 , 86 байт

n=10
while n:print['\/'*n,'('+35/n*2*'-=_='[n%4]+')','.-@@-.'][-2%n/4].center(12);n-=1

Спробуйте в Інтернеті!

Опрацювання рішення Лінни .


-2%n/4так круто :) Ви шукаєте подібні вирази вручну чи виконуєте якийсь грубий пошук?
Лінн

1
@Lynn я керував грубим форссером. Я також робив це для того 35/n*2, що він визначив так, 5*7/n*2оскільки не знає багатозначних чисел.
xnor

1
О, це акуратно. Я хотів би побачити вихідний код!
Лінн


5

05AB1E , 42 байти

•3[ÜAʒg‰ŽÎ<\¦•6¡εS"-.@(=_"sèJ∞}'\∞5LRׂ˜.C

Спробуйте в Інтернеті!


1026344463000063444446355555 зараз номер морозива б / с, його ніхто не використовував.


Full program: •3[ÜAʒg‰ŽÎ<\¦•6¡εS"-.@(=_"sèJ∞}'\∞5LRׂ˜.C
current >> •  ||  stack: []
current >> 6  ||  stack: [1026344463000063444446355555]
current >> ¡  ||  stack: [1026344463000063444446355555, '6']
current >> ε  ||  stack: [['102', '3444', '30000', '344444', '355555']]
For each: S"-.@(=_"sèJ∞
Full program: S"-.@(=_"sèJ∞
current >> S  ||  stack: ['102']
current >> "  ||  stack: [['1', '0', '2']]
current >> s  ||  stack: [['1', '0', '2'], '-.@(=_']
current >> è  ||  stack: ['-.@(=_', ['1', '0', '2']]
current >> J  ||  stack: [['.', '-', '@']]
current >> ∞  ||  stack: ['.-@']
stack > ['.-@@-.']
Full program: S"-.@(=_"sèJ∞
current >> S  ||  stack: ['3444']
current >> "  ||  stack: [['3', '4', '4', '4']]
current >> s  ||  stack: [['3', '4', '4', '4'], '-.@(=_']
current >> è  ||  stack: ['-.@(=_', ['3', '4', '4', '4']]
current >> J  ||  stack: [['(', '=', '=', '=']]
current >> ∞  ||  stack: ['(===']
stack > ['(======)']
Full program: S"-.@(=_"sèJ∞
current >> S  ||  stack: ['30000']
current >> "  ||  stack: [['3', '0', '0', '0', '0']]
current >> s  ||  stack: [['3', '0', '0', '0', '0'], '-.@(=_']
current >> è  ||  stack: ['-.@(=_', ['3', '0', '0', '0', '0']]
current >> J  ||  stack: [['(', '-', '-', '-', '-']]
current >> ∞  ||  stack: ['(----']
stack > ['(--------)']
Full program: S"-.@(=_"sèJ∞
current >> S  ||  stack: ['344444']
current >> "  ||  stack: [['3', '4', '4', '4', '4', '4']]
current >> s  ||  stack: [['3', '4', '4', '4', '4', '4'], '-.@(=_']
current >> è  ||  stack: ['-.@(=_', ['3', '4', '4', '4', '4', '4']]
current >> J  ||  stack: [['(', '=', '=', '=', '=', '=']]
current >> ∞  ||  stack: ['(=====']
stack > ['(==========)']
Full program: S"-.@(=_"sèJ∞
current >> S  ||  stack: ['355555']
current >> "  ||  stack: [['3', '5', '5', '5', '5', '5']]
current >> s  ||  stack: [['3', '5', '5', '5', '5', '5'], '-.@(=_']
current >> è  ||  stack: ['-.@(=_', ['3', '5', '5', '5', '5', '5']]
current >> J  ||  stack: [['(', '_', '_', '_', '_', '_']]
current >> ∞  ||  stack: ['(_____']
stack > ['(__________)']
current >> '  ||  stack: [['.-@@-.', '(======)', '(--------)', '(==========)', '(__________)']]
current >> ∞  ||  stack: [['.-@@-.', '(======)', '(--------)', '(==========)', '(__________)'], '\\']
current >> 5  ||  stack: [['.-@@-.', '(======)', '(--------)', '(==========)', '(__________)'], '\\/']
current >> L  ||  stack: [['.-@@-.', '(======)', '(--------)', '(==========)', '(__________)'], '\\/', '5']
current >> R  ||  stack: [['.-@@-.', '(======)', '(--------)', '(==========)', '(__________)'], '\\/', [1, 2, 3, 4, 5]]
current >> ×  ||  stack: [['.-@@-.', '(======)', '(--------)', '(==========)', '(__________)'], '\\/', [5, 4, 3, 2, 1]]
current >> ‚  ||  stack: [['.-@@-.', '(======)', '(--------)', '(==========)', '(__________)'], ['\\/\\/\\/\\/\\/', '\\/\\/\\/\\/', '\\/\\/\\/', '\\/\\/', '\\/']]
current >> ˜  ||  stack: [[['.-@@-.', '(======)', '(--------)', '(==========)', '(__________)'], ['\\/\\/\\/\\/\\/', '\\/\\/\\/\\/', '\\/\\/\\/', '\\/\\/', '\\/']]]
current >> .  ||  stack: [['.-@@-.', '(======)', '(--------)', '(==========)', '(__________)', '\\/\\/\\/\\/\\/', '\\/\\/\\/\\/', '\\/\\/\\/', '\\/\\/', '\\/']]
   .-@@-.
  (======)
 (--------)
(==========)
(__________)
 \/\/\/\/\/
  \/\/\/\/
   \/\/\/
    \/\/
     \/
stack > ['   .-@@-.\n  (======)\n (--------)\n(==========)\n(__________)\n \\/\\/\\/\\/\\/\n  \\/\\/\\/\\/\n   \\/\\/\\/\n    \\/\\/\n     \\/']

•3[ÜAʒg‰ŽÎ<\¦•               | Pushes 1026344463000063444446355555 to the stack.
-----------------------------+-------------------------------------------------
6¡                           | Split on 6's.
-----------------------------+-------------------------------------------------
  ε             }            | Loop on each piece to create the top of the icecream...
   S                         | Split into single chars.
    "-.@(=_"sè               | Substitute in the correct symbol for each number.
              J∞             | Join, then mirror.
-----------------------------+-------------------------------------------------
                 '\∞         | Push \/.
                    5LR      | Push [5,4,3,2,1]
                       ×     | Multiply '\/' by each 5,4,3,2 and 1.
                        ‚˜   | Join top to bottom.
                          .C | Center w/ newlines.


3

C, 171 байт

i;p(c,n,o){for(printf("%*c",o,i?32:40);n--;)printf(c);puts(i?"":")");}f(){p(".-@@-.",i=1,3);--i;p("=",6,3);p("-",8,2);p("=",10,1);p("_",10,1);for(i=6;--i;)p("\\/",i,6-i);}

Спробуйте в Інтернеті!

C, 146 байт

f(){puts("   .-@@-.\n  (======)\n (--------)\n(==========)\n(__________)\n \\/\\/\\/\\/\\/\n  \\/\\/\\/\\/\n   \\/\\/\\/\n    \\/\\/\n     \\/");}

Просто друкується твердо кодований рядок.

Спробуйте в Інтернеті!


1
Ви можете зробити краще, ніж це я думаю ...
cleblanc

2

Python 2 , 104 байти

Позичив хитрість у відповіді Джонатана Фреха , і дякую йому, що врятував і мене кілька байт.

print"   .-@@-.\n  (======)\n "+"(%s)\n"*3%("-"*8,"="*10,"_"*10),
i=5
while i:print(6-i)*" "+"\/"*i;i-=1

Спробуйте в Інтернеті!


Python 2 , 108 байт

print"""   .-@@-.
  (======)
 (--------)
(==========)
(__________)"""
i=5
while i:print(6-i)*" "+"\/"*i;i-=1

Спробуйте в Інтернеті!




2

Perl 5 , 92 байти

say'   .-@@-.
  (======)
 (--------)
(==========)
(__________)';$_='\/'x6;say while s%\\/% %

Спробуйте в Інтернеті!


Чи не потрібно вважати вхід до кількості байтів? В іншому випадку просто введіть весь рядок ...
cleblanc

Введення немає. Це було просто залишок TIO від чогось іншого, що я робив.
Xcali

круто, отримав спасибі.
cleblanc

+1. Ви можете зберегти пару, використовуючи розшифровку RLE, але я не міг з якихось причин використовувати ;як роздільник для s///роботи. На мобільному телефоні так нічого не можна робити! Спробуйте в Інтернеті!
Дом Гастінгс


1

Пітон 3, 202 байти

Це досить жахливо, його більше байтів, ніж просто визначення рядка і рівномірне друкування.

print("   .-@@-.")
print("  ("+"="*6+")")
print(" ("+"-"*8+")")
print("("+"="*10+")")
print("("+"_"*10+")")
print(" "+"\/"*5)
print("  "+"\/"*4)
print("   "+"\/"*3)
print("    "+"\/"*2)
print("     \/")

Спробуйте це в Інтернеті


6
Ви можете використовувати \nзамість окремих printтверджень
Nissa

148 байт, використовуючи цей підхід
Містер Xcoder

7
Ласкаво просимо до PPCG!
AdmBorkBork

1

Желе , 74 72 байти

5RU⁾\/ẋ
5R×⁶ż¢Y
3,6,8,10,10j1ż“ “.-@@-.¶  (“=“)¶ (“-“)¶(“=“)¶(“_“)¶”P€;¢

Спробуйте в Інтернеті!

Пояснення:

5RU⁾\/ẋ    Link 1. Generate list of "\/"s for cone.
5RU        Range 5, reverse. Gets [5,4,3,2,1].
   ⁾\/     Literal string "\/".
      ẋ    Repeat. Gets ["\/\/\/\/\/","\/\/\/\/","\/\/\/","\/\/","\/"].

5R×⁶ż¢Y    Link 2. Generate rest of cone.
5R         Range 5. Gets [1,2,3,4,5].
  ×⁶       Repeat " " that many times. Gets [" ","  ","   ","    ","     "]
    ż¢     Zip that with the ¢ones. Gets a list of alternating space and cones.
      Y    Join with newlines. This puts it all together for the big cone.

3,6,8,10,10j1ż“ “.-@@-.¶  (“=“)¶ (“-“)¶(“=“)¶(“_“)¶”P€;¢    Link 3. Generate the top and put it on the cone.
10,10,8,6j1;1U                                                Generate list 3,1,6,1,8,1,10,1,10. Does this by joining [10,10,8,6] with ones, appending a one, and reversing.
               “   .-@@-.¶  (“=“)¶ (“-“)¶(“=“)¶(“_“)¶”        List of strings. This separates the completed parts from the non completed parts.
              ż                                               Zip 'em together. Gets [number, string, number, string, ...]
                                                      P€      Get the product of €ach. This completes the non completed strings by repeating them.
                                                        ;¢    Attach the ¢one to the end.

1

Математика, 117 байт

Column[Join[{".-@@-."},"("<>#<>")"&/@{"="~(T=Table)~6,"-"~T~8,"="~T~10,"_"~T~10},T[""<>T["\/",i],{i,5,1,-1}]],Center]


Виходи
введіть тут опис зображення

ви можете протестувати його на пісочниці wolfram (хоча шрифти, які вони використовують, можуть дещо визначити результат)


Цікаво \/- особливий персонаж. Я не міг знайти те , що він використовується для так що я запитав на Mma.SE: mathematica.stackexchange.com/q/200673/61597
lirtosiast




1

C 165 байт

y,x,z;f(){for(puts("   .-@@-.");y++<9;)for(;x=++x%14;)z=y+3-y/4,putchar(x<13?y<5?x-7^z-1?7-x^z?abs(x-7)<z?y<4?y&1?61:45:95:32:40:41:x+y>16|y-x>3?32:x+y&1?92:47:10);}

1

Куби , 345 336 байт

⇒@@@
RU+30f1+3-00@-2+3@+4@@-4@+2-3@-110@+31-4@@+2-4@+10f1f1-3+0@-400@+31-4@+2-4@+3-10f1f1@@-4+1@-400@+11@+10f1f1f1@-3+0@-400@+11@+4110@f1f1f1-22@-400@+31-4@+220@-43@+43@-43@+43@-43@+43@-43@+43@-43@-4000@+31-4@@+220@-43@+43@-43@+43@-43@+43@-43@-4000@+31-4f1+220@-43@+43@-43@+43@-43@-4000@+31-4f1@+220@-43@+43@-43@-4000@+31-4f1@@+220@-43@

Знайдений за допомогою цього інструменту та гольф за допомогою пошуку та заміни, за допомогою декількох спеціальних оптимізацій.

Спробуйте в Інтернеті!


Альтернативний метод:

391 байт (не змінює куб)

+5/1+3@@@:1/1+5@5.0+2@@5.0-2@-4@:5/1+3@@:4/1+4@:5+2/1+51@@@@@@:5/1+4@:1/1+1@:5/1+3@:4/1+4@5.05.05.05.05.05.05.05.0:5/1+4@:1/1+1@:4/1+4@:5+2/1+51@@@@@@@@@@:5/1+4@:1/1+1@:4/1+4@:5/1+55@@@@@@@@@@-51@:1/1+1@:5/1+3@:2/1+55@-5@+5@-5@+5@-5@+5@-5@+5@-5@:1/1+1@:5/1+3@@:2/1+55@-5@+5@-5@+5@-5@+5@-5@:1/1+1@:5/1+3@@@:2/1+55@-5@+5@-5@+5@-5@:1/1+1@:5/1+3@@@@:2/1+55@-5@+5@-5@:1/1+1@:5/1+3@@@@@:2/1+55@-5@

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.