З Днем Бекону!


40

Сьогодні День Бекона , імовірно, саме тому капелюх для участі сьогодні - "Мммм Бекон". Який кращий спосіб відсвяткувати день бекону весело заповненими 2d матрицями, зробленими з бекону! Смужка бекону 1 на 1 представлена ​​таким чином:

----- 
)===)
(===(
)===)
-----

Вашій меті тут даються дві координати в кортежі (( x, y), де xі yє ненульовими додатними цілими числами, ви повинні створити бекон і повернутися в якомусь форматі (список, масив, рядок).

Вхід і вихід:

Input: (2, 1)

Output:
----------  
)===))===)
(===((===(
)===))===)
----------

Input: (1, 2)

Output:

----- 
)===)
(===(
)===)
----- 
)===)
(===(
)===)
-----

Input: (2, 2)

---------- 
)===))===)
(===((===(
)===))===)
---------- 
)===))===)
(===((===(
)===))===)
----------

Правила:

  • Як видно з другого тестового випадку, якщо кілька шматочків бекону складені разом, тільки один -----відокремлюється кожним шматочком бекону вище та / або під ним. Це означає, що укладання бекону таким чином недійсне:

    ----- 
    )===)
    (===(
    )===)
    -----
    ----- 
    )===)
    (===(
    )===)
    -----   
    
  • Стандартні лазівки заборонені

  • Код повинен працювати для вищевказаних тестів і нижче: (4, 4), (1, 6), (5, 1), (2, 3),(3, 2)

  • Надайте перекладача, де можна перевірити вищевказані тестові випадки

Критерії виграшу:

Найкоротший код виграє! З Днем Бекону всім!


Відповіді:


11

V , 28, 26 , 24 байти

Ài)³=)Y4PÒ-G.MÓ)/(
kÀäG

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

Пояснення:

Ài                      " Arg 1 times insert:
  )³=)                  " ')===)'
      <esc>             " Escape back to normal mode
           Y            " Yank this line
            4P          " Paste four times
              Ò-        " Replace this line with '-'
                G.      " Repeat on the last line
                  M     " Move to the middle line
                   Ó)/( " Replace ')' with '('
k                       " Move up (to the second line)
 À                      " Arg 2 times
  äG                    " Duplicate everything up to the last line

3
Мені подобається, як ця відповідь на 3 байти довше, ніж один бекон: D
FlipTack

3
@FlipTack Є нові лінії. Це насправді на 2 коротше. : P
DJMcMayhem

2
Забули про це! Нічого собі, відповідь коротша, ніж будівельні блоки результату. Це деякі речі в стилі деніс.
FlipTack

8

TI-Basic, 80 байт

Цей був насправді досить геніальний :)

":→Str0:Input :For(M,0,4Y:For(N,1,X:")===)
If not(fPart(M/4:"-----
If .5=fPart(M/4:"(===(
Str0+Ans→Str0:End:Ans+":→Str0:End

Крім того, для тих, хто цікавиться, у TI-Basic двокрапка та новий рядок є взаємозамінними, а використання Inputаргументів без аргументів отримує введення за замовчуванням у Xта Y.
Timtech

7

Python 2.7, 74 байти

Я впевнений, що це могло б стати ще одним гольфом, але це те, що я придумав (функція множення рядків Python обов'язково стане у нагоді):

a,b=input();f="-"*5*a;d=")===)"*a;print'\n'.join([f,d,"(===("*a,d,''])*b+f

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

Необурені з поясненням:

a,b = input()                                       # Take input from the user as a tuple
f = "-"*5 * a                                       # f is the delimiter between bacons
d = ")===)" * a                                     # 2nd and 4th lines of bacon
print '\n'.join([f, d, "(===("*a, d, ''])*b + f     # Join everything together!

5

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

Array[b["-----",b=")===)","(===("][[#~Mod~4]]&,{4#2+1,#}]~Riffle~"\n"<>""&

Безіменна функція, що приймає два позитивних цілих аргументи та повертає рядок з новими рядками. Стандартний підхід Mathematica: побудуйте 2d масив рядків за допомогою вибору (mod 4) для циклу рядків у вертикальному напрямку, а потім згорніть їх до однієї струни.


4

Пакетна, 168 байт

@set s=
@for /l %%i in (1,1,%1)do @call set s=%%s%%-___-
@set t=%s:_==%
@echo %s:_=-%
@for /l %%i in (1,1,%2)do @echo %t:-=)%&echo %t:-=(%&echo %t:-=)%&echo %s:_=-%

На жаль, я не можу написати @echo %s:==-%інакше, що усуне необхідність другої змінної.


Збережіть 2 байти, об’єднавши рядки 1,2 і 3,4 за допомогою &
Magoo

4

C, 91 89 байт

i;f(w,h){w=w*5+1;for(i=0;i<w*4*h+w;++i)putchar(i%w<w-1?i/w%4?i%w%5%4?61:40+i/w%2:45:10);}

4

05AB1E , 25 байт

Код:

…)==û×Ь'(:s)¬g'-×=¸«»²F=

Пояснення:

…)==û                         # Push the string ")===)"
     ×                        # String multiply by the first input
      Ð                       # Triplicate the string
       ¬                      # Take the first character, which is a ')' and push
        '(:                   # Replace by '('
           s                  # Swap the top two elements
            )                 # Wrap everything into an array
             ¬g               # Get the length of the first element in the array
               '-×            # And repeat the character '-' that many times
                  =           # Print it without popping
                   ¸«         # Append the string of dashes to the array
                     »        # Join by newlines
                      ²F      # Second input times do...
                        =     #   Print the top of the stack without popping

Використовує кодування CP-1252 . Спробуйте в Інтернеті!


4

05AB1E , 32 30 байт

Збережено 2 байти завдяки Аднану .

'-5×…)==ûÐ')'(:s)vy¹×})I.D¬)˜»

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

Пояснення

'-5×                            # push "-----" 
    …)==ûÐ                      # push 3 copies of ")===)"
          ')'(:s                # replace ")" with "(" in the 2nd copy
                )               # wrap in list
                 vy¹×})         # repeat each list entry input-1 times
                       I.D      # repeat list input-2 times
                          ¬     # push the first element of the list ("-----")
                           )˜   # wrap in list and flatten
                             »  # join by newline

Ви можете замінити ")===)"на …)==û:)
Аднан

@Adnan: Ну звичайно! Дякую!
Емінья

3

Python 2 , 70 байт

def f(w,h):n=4*h+1;exec"n-=1;print'-)()-===-===-===-)()'[n%4::4]*w;"*n

Дякуємо @xnor за збереження 4 байтів!

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


Схоже, що рядки не чергуються із напрямками у вашому тестовому випадку.
xnor

Схоже, це [_::3]було б коротше.
xnor

Ой стріляй, там щось пішло не так. Видалення, поки я не можу це виправити.
Денніс

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

Там 2**n%5%3які цикли [1, 2, 1, 0, 1, 2, 1, 0, ...]. Чи може це бути корисно?
xnor

3

Python 2, 59 байт

w,h=input()
for a in'-()('*h+'-':print(a+3*'=-'[a>')']+a)*w

Створює кожен рядок як a+b*3+aз початкового символу, так aі з центрального символу b(який обчислюється з a). У aциклі «S через '-()(', в той час як bце , '-'коли aце '-', а в '='іншому випадку.


67 байт:

w,h=input()
for a,b in['--']+zip(')()-','===-')*h:print(a+b*3+a)*w

Створює кожен рядок із його зовнішнього aта центрального символу bяк a+b*3+a, а потім друкує його wкопії. Ці цикли через a zip.


3

JavaScript, 132 129 121 байт

-8 байт завдяки @ user2428118

(x,y)=>{a=b=["-----",")===)","(===(",")===)","-----"];for(i=0;++i<y;){b=[...b,...a.slice(1)]}return b.map(v=>v.repeat(x)).join(`
`)}

(x,y)=>eval('a=b=["-----",")===)","(===(",")===)","-----"];for(i=0;++i<y;)b=[...b,...a.slice(1)];b.map(v=>v.repeat(x)).join`\n`')

(x,y)=>eval('a=b=[c="-----",d=")===)","(===(",d,c];for(i=0;++i<y;)b=[...b,...a.slice(1)];b.map(v=>v.repeat(x)).join`\n`')

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


побили мене на 1 байт .. :(
devRicher

@devRicher Але я ще не точно обіграв гольф. :)
ericw31415

@devRicher Насправді я випадково пропустив новий рядок. Уопс. Редагувати: Я зараз тебе побив.
ericw31415

1
@ ericw31415 (x,y)=>eval('a=b=[d="-----",c=")===)","(===(",c,d];for(i=0;++i<y;)b=[...b,...a.slice(1)].map(v=>v.repeat(x)).join_BACKTICK NEWLINE BACKTICK_;')
користувач2428118

@ user2428118 Це не працює? Я можу використовувати ваше спрощення масиву. :)
ericw31415

2

Луа, 132 байти

a="-----"b=")===)"c="(===("w,z=io.read(),io.read()function g(f)return f:rep(w).."\n"end print((g(a)..g(b)..g(c)..g(b)):rep(z)..g(a))

Довга буквальна спроба струни. Спробуйте тут .


2

JavaScript (ES6), 78

(x,y,r=s=>`${s}`.repeat(x)+`
`,a=r`)===)`,c=r`-----`)=>c+r(a+r`(===(`+a+c,x=y)

Тест

F=
(x,y,r=s=>`${s}`.repeat(x)+`
`,a=r`)===)`,c=r`-----`)=>c+r(a+r`(===(`+a+c,x=y)

function update() {
  var x=+X.value,y=+Y.value
  O.textContent=F(x,y)
}

update()
X<input type=number id=X value=1 min=1 oninput='update()'>
Y<input type=number id=Y value=1 min=1 oninput='update()'>
<pre id=O></pre>


1

GameMaker Language, 160 139 148 байт 133 байт

x=argument0 y=argument1*4for(m=0;m<=y;m++){for(n=0;n<x;n++){a=")===)"if !m mod 4a="-----"else if n mod 2a="(===("r+=a}r+="#"}return r

Також перед тим, як запропонувати його, GML вимагає, щоб кожна частина циклу for
містила

1

Желе , 26 байт

4“\ḊƭVṠ’bị“-=()”s5ẋ€ḷẋµ1ịṭ

Це діадійна посилання (функція), яка повертає 2D масив.

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

Як це працює

4“\ḊƭVṠ’bị“-=()”s5ẋ€ḷẋµ1ịṭ  Main link. Left argument: w. Right argument: h

4                           Set the return value to 4.
 “\ḊƭVṠ’b                   Yield 366323084456 and convert it to base 4.
                            This yields [1,1,1,1,1,0,2,2,2,0,3,2,2,2,3,0,2,2,2,0].
         ị“-=()”            Index into that string, using modular 1-based indexing.
                s5          Split the result into chunks of length 5.
                  ẋ€ḷ       Repeat the characters of each chunk w times.
                     ẋ      Repeat the array of chunks h times.
                      µ     Begin a new, monadic chain. Argument: M (bacon matrix)
                       1ị   Retrieve the first line.
                         ṭ  Tack; append it to M.

0

C, 159 158 153 байт

p(s,n){printf(s,--n?p(s,n):0);}i,j;b(n,m){p("-----",n);for(j=3;j--;){p("\n",1);for(i=n;i--;)p(j%2?"(===(":")===)",1);}p("\n",1);--m?b(n,m):p("-----",n);}

Телефонуйте за допомогою:

int main()
{
    b(2,3);
}

Приємно бачити ще одну відповідь на С, але це можна зробити трохи коротше, дивіться мою відповідь :)
orlp

0

C #, 160 байт

x=>y=>{int i=0,h=4*y+1,j;var s=new string[h];for(;i<h;++i)if(i%4<1)s[i]=new string('-',x*5);else{var c=i%2>0?')':'(';for(j=0;j++<x;)s[i]+=c+"==="+c;}return s;};

Відформатована версія:

x => y =>
{
    int i = 0, h = 4 * y + 1, j;

    var s = new string[h];

    for (; i < h; ++i)
        if (i % 4 < 1)
            s[i] = new string('-', x * 5);
        else
        {
            var c = i % 2 > 0 ? ')' : '(';

            for (j = 0; j++ < x; )
                s[i] += c + "===" + c;
        }

    return s;
};

Спробуйте в Інтернеті! (чомусь це посилання дає помилку, але все одно працює)



0

Діалог APL, 55 байт

Це вперше я використовую Dyalog APL, тому я впевнений, що це не найкращий підхід.

 {(⊂'-----'),[1]⍉⍺(4×⍵)⍴')===)' '(===(' ')===)' '-----'}

Пояснення: Це досить простий підхід: для сітки бекону N × M я роблю матрицю N × (4M) з чотирьох наступних рядків, повторюючи:

')===)'
'(===('
')===)'
'-----'

Тоді я з'єдную рядок -----на початок.

Ось коротке пояснення коду:

')===)' '(===(' ')===)' '-----'  ⍝ An array of the four strings        

⍺ (4×⍵) ⍴                        ⍝ reshape (⍴) the array to a matrix with the dimensions
                                 ⍝ ⍺ by (4×⍵) (⍺ is the 1st argument and ⍵ is the second) 

⍉                               ⍝ transpose the matrix 

,[1]                             ⍝ concatenate to beginning of the matrix...

(⊂'-----')                       ⍝ ...the string '-----' embedded in its own matrix (⊂)


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