91 Пляшки ASCII-пива на Стіні


17

Дано єдине ціле число, xде 0 <= x <= 91виводять стопку пляшок пива з такою кількістю пляшок (і полиць). Для простоти я покажу лише перші 6 пляшок і що це буде для кожного з перших входів.

Ось стопка пляшок, кожне число - це пляшка, яку слід вийняти для цього вводу (1-індексований):

https://pastebin.com/wSpZRMV6


Зауважте, ми використовуємо 91 замість 99, оскільки 99 призведе до нестабільної купки пляшок.


Приклад

З відсутністю 0 пляшок ( x=0):

             |=|            
             | |            
             | |            
            /   \           
           .     .          
           |-----|          
           |     |          
           |-----|          
           |_____|          
        =============       
         |=|     |=|        
         | |     | |        
         | |     | |        
        /   \   /   \       
       .     . .     .      
       |-----| |-----|      
       |     | |     |      
       |-----| |-----|      
       |_____| |_____|      
    =====================    
     |=|     |=|     |=|     
     | |     | |     | |     
     | |     | |     | |     
    /   \   /   \   /   \    
   .     . .     . .     .   
   |-----| |-----| |-----|   
   |     | |     | |     |   
   |-----| |-----| |-----|   
   |_____| |_____| |_____|   
=============================
 [THERE ARE MORE UNDER THIS]

Повний вихід 0 див. Тут: https://pastebin.com/ZuXkuH6s


Якщо 1пляшка відсутня ( x=1):

         |=|     |=|        
         | |     | |        
         | |     | |        
        /   \   /   \       
       .     . .     .      
       |-----| |-----|      
       |     | |     |      
       |-----| |-----|      
       |_____| |_____|      
    =====================    
     |=|     |=|     |=|     
     | |     | |     | |     
     | |     | |     | |     
    /   \   /   \   /   \    
   .     . .     . .     .   
   |-----| |-----| |-----|   
   |     | |     | |     |   
   |-----| |-----| |-----|   
   |_____| |_____| |_____|   
=============================
 [THERE ARE MORE UNDER THIS]

Ще раз, це перші два ряди звідси: https://pastebin.com/ZuXkuH6s (з 1 вилученим) ...


З відсутністю 2 пляшок:

                 |=|        
                 | |        
                 | |        
                /   \       
               .     .      
               |-----|      
               |     |      
               |-----|      
               |_____|      
    =====================    
     |=|     |=|     |=|     
     | |     | |     | |     
     | |     | |     | |     
    /   \   /   \   /   \    
   .     . .     . .     .   
   |-----| |-----| |-----|   
   |     | |     | |     |   
   |-----| |-----| |-----|   
   |_____| |_____| |_____|   
=============================
 [THERE ARE MORE UNDER THIS]

[ДОДАТКОВІ ВХОДИ ВІДКРИТИ]


З відсутньою 91 пляшки ( n = 91):

:(

Ви повинні вивести нещасне обличчя, бо ви не пива.


Правила

  • Пляшки потрібно знімати зліва направо.
  • Полиці прибирають, коли на верхній полиці не залишається пива.
  • Для введення 0 ви виводите 91 пляшку, складену в трикутник.
    • У нижньому ряду 13 пляшок, у верхньому - 1.
  • 1 простір між кожною пляшкою на кожній полиці.
  • Полиці повинні бути введені між кожним рядом пляшок.
    • Полиці можуть використовувати =, -або #як символ.
    • Полиці повинні бути на 3 ширші (з боків), ніж у пляшок, у яких вони є.
  • Це , виграє найменший байт.

Не могли б ви надати, скажімо, пастбін принаймні одного з усіх тестових випадків?
Conor O'Brien

Чи потрібні пробіли після останньої пляшки на полиці?
Джонатан Фрех

Попередні пробіли потрібні, оскільки ви видаляєте їх зліва направо, пробіли праворуч від ASCII-мистецтва залежать від вас.
Чарівний восьминіг Урна

@ ConorO'Brien бачачи, як ви не вказали, який тестовий випадок, я б хотів, щоб я поклав нещасне обличчя в пастбін; P.
Чарівний восьминіг Урна

1
О, я думав, ви вибрали 91, щоб запобігти будь-якому вбудованому типу. o0
повністюлюдський

Відповіді:


15

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

A⁻⁹¹NθA¹³η:(Wθ«A⌊⟦θη⟧ζA⁻θζθA⁻η¹ηFζ«↑⁴↖.\↑²←|=↓³←↙¹↓.P⁶↓²P⁶↓¹P______←| »¿θ«M⁹↑M³→×=⁻×⁸ζ³↑M⁴←

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

F¹⁵Fι⊞υκ:(F⁻⁹¹N«F¬⊟υ«M³±⁹×=⁺⁵×⁸⊟υ↑M⁴←»↑⁴↖.\↑²←|=↓³←↙¹↓.P⁶↓²P⁶↓¹P×_⁶←|←

Пояснення:

F¹⁵Fι⊞υκ

Наповніть масив, який надає інформацію про те, куди йдуть полки та тривалість.

:(

Роздрукуйте нещасне обличчя, хоча це буде негайно переписано першою пляшкою пива (якщо така є).

F⁻⁹¹N«

Пропустіть через пляшки пива, що залишилися.

   F¬⊟υ«

Перевірте, чи потрібно намалювати поличку.

        M³±⁹×=⁺⁵×⁸⊟υ↑M⁴←»

Роздрукуйте поличку і готові, щоб намалювати наступну пляшку над нею.

   ↑⁴↖.\↑²←|=↓³←↙¹↓.P⁶↓²P⁶↓¹P×_⁶←|←

Намалюйте пляшку і поставте готову, щоб намалювати ще одну пляшку.


6
Ага. Шкода, що цей виклик не стосується 99 пляшок пива. У вас є 8 байт вниз :): P
HyperNeutrino

1
@EriktheOutgolfer Ось чому я запропонував гольфу 8 байт: P І так, він насправді робив гольф 8 байт: D
HyperNeutrino

2
@HyperNeutrino Не зовсім так; Я грав у гольф 11, а потім без вогню 3 ...
Ніл

1
@KevinCruijssen Зазвичай ви збільшуєте за допомогою forциклу. Це whileцикл, тому я повинен зробити якусь справу більш вручну.
Ніл

1
@KevinCruijssen Хоча, думаючи про це, forцикл був способом пройти весь час ... 13 байт збережено! (Ну, мені трохи пощастило з легкістю заповнення мого масиву.)
Ніл,

10

Python 3 , 306 299 265 253 255 252 247 244 байт

Швидка спроба, може бути оптимізована

Редагувати: -2 байти завдяки @MrXcoder

Редагувати: -32 байти, оскільки пробіли не потрібні

Редагувати: -12 байт, поєднуючи дві функції

Редагувати: -5 байт завдяки @ musicman523

Редагувати: +7 байт, щоб видалити полицю після останнього рядка

Редагувати: -3 байти

Редагувати: -5 байт через функцію лямбда, що використовується лише один раз на карті

Змінити: -3 байти за допомогою функції рядкаcenter

def l(y,x=13,z=" "):b=min(x,91-y);A,D="  |%s|  ","|-----|";print(y<91and(l(y+x,x-1)or"".join(map(lambda t:((t+z)*b)[:-1].center(103)+"\n",(A%"=",A%z,A%z," /   \ ",".     .",D,"|     |",D,"|_____|")))+z*(49-4*x)+"="*(x*8+5)*(x<13))or(x>12)*":(")

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


@ Mr.Xcoder, який не працюватиме для x = 2, x = 4, x = 5, x = 7, ...
Halvard Hummel

О, ти маєш рацію. Вибачте!
Містер Xcoder


2
248 байт , видаливши Eзмінну
musicman523

5

JavaScript (ES6), 251 256 байт

Редагувати: збережено 2 байти завдяки @dzaima .
Редагувати: для усунення проблеми з параметром додано 7 байт.:(

c=>(f=(c,w=13)=>c>0&&f(c-w,w-1)+(c=c<w?c:w,r=(n,s=' ')=>s.repeat(n),a='\n'+r(52-w*4),'  |=|  0  | |  0  | |  0 /   \\ 0.     .0|-----|0|     |0|-----|0|_____|'.split(0).map(x=>a+r((w-c)*8+2)+r(c,' '+x)).join('')+a+r(w*8+5,'#')),(c=91-c)?f(c).slice(6):':(')

Ось (здебільшого) безгольова версія:

function (consumed) {
  let remaining = 91 - consumed;

  function inner (count, width = 13) {
    if (count <= 0) return false;

    function repeat (count, string = ' ') {
      return string.repeat(count);
    }

    const pattern = [
      '  |=|  ',
      '  | |  ',
      '  | |  ',
      ' /   \\ ',
      '.     .',
      '|-----|',
      '|     |',
      '|-----|',
      '|_____|' ];

    let clamped = Math.min(count, width);
    let alignment = '\n' + repeat((13 - width) * 4);
    let empty = alignment + repeat((width - clamped) * 8 + 2);
    let shelf = alignment + repeat((width * 8) + 5, '#');
    let bottles = pattern.map(row => empty + repeat(clamped, ' ' + row));

    return inner(count - width, width - 1) + bottles.join('') + shelf;
  }

  return (remaining) ? inner(remaining).slice(6) : ':(';
}

Код тесту


Дуже вражаюча, чудова відповідь. Мені подобається твій r«макрос»; Я відчував, що може бути коротший метод, але нічого, що я намагався, не збило його.
ETHproductions

2

C (gcc) , 360 358 байт

#define P printf(
r,i,j;char*b[]={"  |=|  ","  | |  ","  | |  "," /   \\ ",".     .","|-----|","|     |","|-----|","|_____|"};w(n){P"%*c",n,' ');}main(n,a)char**a;{(n=-atoi(a[1]))<-90?P":(\n"):({while(++r<14)if((n+=r)>0){for(j=0;j<9;++j){w(4*(13-r)+1);for(i=r;i>0;)--i<n?P b[j]),w(1):w(8);P"\n");}if(r<13){w(4*(13-r)-2);for(i=0;++i<8*r+6;)P"=");P"\n");}}});}

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

Пояснення:

#define P printf(
r,i,j;
char*b[]={
    "  |=|  ",
    "  | |  ",
    "  | |  ",
    " /   \\ ",
    ".     .",
    "|-----|",
    "|     |",
    "|-----|",
    "|_____|"};

// function to print `n` spaces:
w(n){P"%*c",n,' ');}

main(n,a)char**a;
{
    // no beer left?
    (n=-atoi(a[1]))<-90

        // sad face
        ?P":(\n")

        // else create stack
        // using GCC extension "expression statement" `({ <statement> })` here,
        // shorter than if-else or a function call
        :({
            // loop over 13 rows
            while(++r<14)

                // found non-empty row?
                if((n+=r)>0)
                {
                    // loop over text lines of beer bottles
                    for(j=0;j<9;++j)
                    {
                        w(4*(13-r)+1);

                        // for each bottle
                        for(i=r;i>0;)

                            // print either 8 spaces or line of the bottle
                            --i<n?P b[j]),w(1):w(8);P"\n");
                    }

                    // except for last row, ...
                    if(r<13)
                    {
                        // ... print shelf
                        w(4*(13-r)-2);
                        for(i=0;++i<8*r+6;)
                            P"=");
                        P"\n");
                    }
                }
        });
}

0

Python 2, 436 байт

Yikes !!

Мій метод занадто багатослівний, але все одно: він по суті 'малює' кожен ряд пляшок, додає пробіли, а потім 'стирає' все необхідне, друкуючи все, що залишилося.

B=['  |=|   ','  | |   ','  | |   ',' /   \\  ','.     . ','|-----| ','|     | ','|-----| ','|_____| ']
N=lambda r:sum(n for n in range(1,r+1))
n=input()
R=0
while N(R)<n:R+=1
L=R-n+N(R-1)
e=range(1,R)+([R],[])[L!=0]
for r in range(1,14):
    if r in e:continue
    if(r-1 in e)<1:print('',' '*(1+(13-r)*4)+'='*(r*8-3))[r!=1]
    i=(0,R-L)[r==R];w=(8*i+(13-r)*4,0)[i==0];print'\n'.join([' '*w+((13-r)*4*' '+l*r)[w:]for l in B])
if n=91:print':('

Халвард Гуммель набагато краще.

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