Побудуйте сходи ASCII


28

Враховуючи вхід двох цілих чисел n і m , виведіть ASCII сходи довжиною n і розміром m .

Це драбина ASCII довжиною 3 та розміром 3:

o---o
|   |
|   |
|   |
+---+
|   |
|   |
|   |
+---+
|   |
|   |
|   |
o---o

Це драбина ASCII довжиною 5 і розміром 1:

o-o
| |
+-+
| |
+-+
| |
+-+
| |
+-+
| |
o-o

Це драбина ASCII довжиною 2 та розміром 5:

o-----o
|     |
|     |
|     |
|     |
|     |
+-----+
|     |
|     |
|     |
|     |
|     |
o-----o

Щоб бути конкретним:

  • Довжина ( n ) означає, скільки квадратів складається з драбини.

  • Розмір ( м ) являє собою ширину і висоту внутрішніх приміщень, тобто без урахування "меж" - кожного квадрата.

  • Кожен квадрат складається із внутрішньої площі, заповненої пробілами, оточеними -s вгорі та знизу |s, зліва та справа +s , та s у всіх чотирьох кутах.

  • Межі між квадратами зливаються разом, тому два рядки підряд +--...--+зливаються в один.

  • Кути всієї драбини замінені символом o.

  • Ви можете необов'язково вивести новий рядок.

Довжина сходів ( n ) завжди буде ≥ 2, а розмір ( m ) завжди буде ≥ 1.

Введення можна сприймати як рядок, розділений пробілом / комою, масив / список / тощо., Або два функції / командний рядок / тощо. аргументи. Аргументи можна приймати в тому порядку, який є найзручнішим / найзручнішим.

Оскільки це , виграє найкоротший код у байтах.

Порада. Наведені вище приклади також можна використовувати як тестові приклади.


Чи потрібно брати спочатку довжину, а потім розмір?
РК.

@RK. Ви можете приймати їх у тому порядку, де зручніше.
Дверна ручка

1
Чи може бути провідний новий рядок?
Conor O'Brien

1
@ CᴏɴᴏʀO'Bʀɪᴇɴ Uhh ... Я збираюся піти з ні на що.
Дверна ручка

1
Гаразд: P Це варто було зняти.
Conor O'Brien

Відповіді:


4

Pyth, 34 байти

.NjjNm*QTvz*2YjC:M++J"+|o"m"- -"QJ

Тестовий набір

Приймає аргументи з новим рядком, розділеним на STDIN.

Використовує хелперну функцію, :яка будує кожен тип вертикальної рядки з трьох символів, потім реплікує за необхідності, переміщує та приєднується до нових рядків.


11

Рубі, 71

->m,n{h=0;(?o+?+*(n-1)+?o).chars{|c|puts [?|+' '*m+?|]*h,c+?-*m+c;h=m}}

unolfolf у тестовій програмі

f=->m,n{
  h=0                             #The number of | above the 1st rung is 0
  (?o+?+*(n-1)+?o).chars{|c|      #Make a string of all the rung ends o++...++o and iterate through it
    puts [?|+' '*m+?|]*h,         #draw h vertical segments |  ...  |
      c+?-*m+c                    #and a rung with the correct ends
    h=m                           #The number of | above all rungs except the 1st is m
  }
}


f[gets.to_i,gets.to_i]

Здається, що з версією для гольфу виникають незначні проблеми: потрібно ;після h=0, потребує місця після puts. Але ви оцінюєте лише 1 символ, оскільки раніше є додаткове місце puts.
манатство

@manatwork на жаль, спасибі, виправлено. Я не знаю, як це сталося, я, мабуть, займався гольфом і не бігав після цього.
Річка рівня Св.

9

CJam, 43 42 байт

Я не заспокоєний рахунком. Але я не Денніс, правда?

q~:Z;'-'o{[\Z*1$N]}:X~['-_'+X\'|XZ*]@*1>1$

Вхід - 2 місця, розділені пробілом. Довжина перша

2 3
o---o
|   |
|   |
|   |
+---+
|   |
|   |
|   |
o---o

Пояснення

q~:Z;'-'o{[\Z*1$N]}:X~['-_'+X\'|XZ*]@*1>1$
q~                                         e# read input
  :Z;                                      e# Record the size in Z and discard
     '-'o{[\Z*1$N]}:X~                     e# Create the initial line (and final). also creates a shorcut to do this later
           \                               e# Capture two arguments
            Z*                             e# The separator is repeated size times
              1$                           e# Repeat the first argument
                N                          e# Add newline
                                           e# X is a function to create line in a ladder
                      ['-_'+X\'|XZ*]       e# Design the repeating part
                                    @*     e# Repeat the pattern n times
                                      1>   e# Discard the initial
                                        1$ e# Since the final line is same than the initial, we just write it.
                                           e# Implicit printing

1
Мені подобається, що ти це сформулював як питання. "Я не Денніс ... правда?"
підземниймонорельс

7

JavaScript (ES6), 89

... повторити, повторити, повторити ...

(n,m,R=x=>x.repeat(m),b=R(`|${R(' ')}|
`),d=`o${c=R('-')}o
`)=>d+R(b+`+${c}+
`,m=n-1)+b+d

Тест

F=(n,m,R=x=>x.repeat(m),b=R(`|${R(' ')}|
`),d=`o${c=R('-')}o
`)=>d+R(b+`+${c}+
`,m=n-1)+b+d

// Less golfed
U=(n,m)=>
{
  var R=x=>x.repeat(m),
      a=R(' '),
      b=R(`|${a}|\n`);
      c=R('-'),
      d=`o${c}o\n`;
  m=n-1;
  return d+R(b+`+${c}+\n`)+b+d
}

function test() {
  var i=I.value.match(/\d+/g)
  if (i) O.textContent=F(+i[0],+i[1])
  console.log(i,I.value)
}  
 
test()
N,M: <input id=I value="3,5" oninput=test()>
<pre id=O></pre>


Я не знав, що document.getElementById('elem').його можна замінити elem.! +1 для цього, але будь ласка, ви могли б вказати на деякі документи з цього приводу?
Ф. Хаурі

2
@ F.Hauri працює майже в кожному браузері, але цього слід уникати (крім випадків кодування для розваги). Інформація та посилання stackoverflow.com/questions/3434278 / ...
edc65

6

C #, 1412 байт

... Моя перша спроба CodeGolf, Мабуть, не виграє, але вона працює так, ось ми:

using System;

namespace Ascii_Ladders
{
    class Program
    {
        static void Main(string[] args)
        {
            int n = 0;
            int m = 0;

            Console.Write("Please enter Height: ");
            n = int.Parse(Console.ReadLine());
            Console.Write("Please Enter Width: ");
            m = int.Parse(Console.ReadLine());

            Console.Write("o");
            for (int i = 0; i < m; i++)
            {
                Console.Write("-");
            }
            Console.WriteLine("o");

            for (int k = 0; k < n; k++)
            {
                for (int i = 0; i < m; i++)
                {
                    Console.Write("|");
                    for (int j = 0; j < m; j++)
                    {
                        Console.Write(" ");
                    }
                    Console.WriteLine("|");
                }
                if (k != n - 1)
                {
                    Console.Write("+");
                    for (int i = 0; i < m; i++)
                    {
                        Console.Write("-");
                    }
                    Console.WriteLine("+");
                }
            }

            Console.Write("o");
            for (int i = 0; i < m; i++)
            {
                 Console.Write("-");
            }
            Console.WriteLine("o");

            Console.ReadKey();
        }
    }
}

9
Ласкаво просимо до головоломки програмування та коду для гольфу! У вашому коді багато пробілів, які ви можете видалити, щоб скоротити код, якщо ви хочете більше допомогти в гольф-коді, ви можете ознайомитись із порадами щодо гольфу в C # .
Пуховик

Я згоден з @ Doᴡɴɢᴏᴀᴛ тут. Я міг потенційно пограти в гольф лише до 533 байт . Але може бути і краще. (Попередження: я не програмую на C #.)
user48538

Я отримав це до 314 рокуusing System;class P{static int m;static void Main(){int n = int.Parse(Console.ReadLine());m = int.Parse(Console.ReadLine());M('o','-');for(int k=0;k<n;k++){for(int i=0;i<m;i++){M('|',' ');}if(k!=n-1){M('+','-');}}M('o','-');Console.ReadKey();}static void M(char x,char y){Console.WriteLine(x+new string(y,m)+x);}}
RedLaser

3
Пропущено кілька пробілів, так 310 зusing System;class P{static int m;static void Main(){int n=int.Parse(Console.ReadLine());m=int.Parse(Console.ReadLine());M('o','-');for(int k=0;k<n;k++){for(int i=0;i<m;i++){M('|',' ');}if(k!=n-1){M('+','-');}}M('o','-');Console.ReadKey();}static void M(char x,char y){Console.WriteLine(x+new string(y,m)+x);}}
RedLaser

2
Аж до 270 без змін в підході використовується: using C=System.Console;class P{static void Main(){int i,k,n=int.Parse(C.ReadLine()),m=int.Parse(C.ReadLine());System.Action<char,char> M=(x,y)=>C.WriteLine(x+new string(y,m)+x);M('o','-');for(k=0;k<n;k++){for(i=0;i<m;i++){M('|',' ');}if(k<n-1){M('+','-');}}M('o','-');}}. Тут, швидше за все, є більше потенціалу, просто змінивши, як робити речі.
Джої

6

Джулія, 87 байт

f(n,m)=(g(x)=(b=x[1:1])x[2:2]^m*b*"\n";(t=g("o-"))join([g("| ")^m for i=1:n],g("+-"))t)

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

Безголівки:

function f(n::Int, m::Int)
    # Create a function g that takes a string of two characters and
    # constructs a line consisting of the first character, m of the
    # second, and the first again, followed by a newline.
    g(x) = (b = x[1:1]) * x[2:2]^m * b * "\n"

    # Assign t to be the top and bottom lines. Construct an array
    # of length n where each element is a string containing the
    # length-m segment of the interior. Join the array with the
    # ladder rung line. Concatenate all of this and return.
    return (t = g("o-")) * join([g("| ")^m for i = 1:n], g("+-")) * t
end

5

pb - 147 байт

^t[B]>>[B]vw[T!0]{b[43]<[X]b[43]>w[B=0]{b[45]>}v[X-1]w[B=0]{b[124]^}v[X]t[T-1]}t[111]b[T]<w[X!0]{b[45]<}b[T]w[Y!0]{w[B!0]{^}b[124]^}b[T]^>>[B]vb[T]

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

Спочатку приймає довжину введення, а потім розмір. Вводиться у вигляді значень байтів, наприклад:python -c 'print(chr(5) + chr(7))' | ./pbi.py ladder.pb

Подивіться, весела анімація!

З коментарями:

^t[B]            # Save length to T
>>[B]v           # Go to X=size+1, Y=0

w[T!0]{          # While T is not 0:
    b[43]            # Write a '+'
    <[X]b[43]        # Write a '+' on the left side as well
    >w[B=0]{b[45]>}  # Travel back to the right '+', writing '-' on the way
    v[X-1]           # Go down by X-1 (== size)
    w[B=0]{b[124]^}  # Travel back up to the '+', writing '|' on the way
    v[X]             # Go down by X (== size + 1, location of next '+')
    t[T-1]           # Decerement T
}

t[111]           # Save 'o' to T (it's used 4 times so putting it
                 # in a variable saves bytes)

b[T]             # Write an 'o' (bottom right)

<w[X!0]{         # While not on X=0:
    b[45]<           # Travel left, writing '-' on the way
}

b[T]             # Write an 'o' (bottom left)

w[Y!0]{          # While not on Y=0:
    w[B!0]{^}        # Skip nonempty spaces
    b[124]           # Write a '|'
    ^                # Travel up
}

b[T]             # Write an 'o' (top left, replaces existing '+')

^>>[B]v          # Go back to where the size is saved and go to X=size+1, Y=0

b[T]             # Write an 'o' (top right, replaces existing '+')

5

Чистий баш, 132 130 128 127 байт

Так, я міг би скинути ще 1 байт, замінивши останній ${p% *}, але я віддаю перевагу цьому:

p=printf\ -v;$p a %$1s;$p b %$2s;o="|$a|\n";h=+${a// /-}+\\n v=${a// /$o}
a=${b// /$h$v}${h//+/o};a=${a/+/o};${p% *} "${a/+/o}"

Зразок:

ladders() {
    p=printf\ -v;$p a %$1s;$p b %$2s;o="|$a|\n";h=+${a// /-}+\\n v=${a// /$o}
    a=${b// /$h$v}${h//+/o};a=${a/+/o};${p% *} "${a/+/o}"
}

ladders 3 4
o---o
|   |
|   |
|   |
+---+
|   |
|   |
|   |
+---+
|   |
|   |
|   |
+---+
|   |
|   |
|   |
o---o

ladders 2 1
o--o
|  |
|  |
o--o

4

Haskell, 100 97 байт

l#s=unlines$t:m++[t]where _:m=[1..l]>>["+"!"-"]++("|"!" "<$u);t="o"!"-";o!i=o++(u>>i)++o;u=[1..s]

Приклад використання:

*Main> putStr $ 4 # 3
o---o
|   |
|   |
|   |
+---+
|   |
|   |
|   |
+---+
|   |
|   |
|   |
+---+
|   |
|   |
|   |
o---o

Як це працює:

l#s=unlines$t:m++[t]         -- concat top line, middle part and end line
                             -- with newlines between every line
  where                      -- where
  _:m=                       -- the middle part is all but the first line of
     [1..l]>>                -- l times
         ["+"!"-"]           --    a plus-dashes-plus line
         ++("|"!" "<$u)      --    followed by s times a bar-spaces-bar line

  t="o"!"-"                  -- very first and last line
  o!i=o++(u>>i)++o           -- helper to build a line
  u=[1..s]

Редагувати: @Christian Irwan знайшов 3 байти. Спасибі!


Розбір шаблонів на -1 бал m=init$[1..l]>>("|"!" "<$u)++["+"!"-"]=>(_:m)=[1..l]>>["+"!"-"]++("|"!" "<$u)
Акангка

Дивно _:m=[1..l]>>["+"!"-"]++("|"!" "<$u)працює
Акангка

@ChristianIrwan: добре помічений! Спасибі!
німі

3

мозковий ебать - 334 байти

,[<+<<<<+>>>>>-]<[[>>]+[<<]>>-]<----[>---<----]--[>[+>>]<<[<<]>++++++]>[+.>>]-[<+>---]<+++++++>>--[<+>++++++]->---[<------->+]++++++++++[<++<]+++++[>[++++++>>]<<[<<]>-]>[-]>.-<<----[>>+++<<----]--[>+<--]>---<<<<++++++++++.,[>[>+>+<<-]>[<+>-]>[<<<<[>>>>>>[.>>]<<[<<]>>-]>>>>>[.>>]<<[<<]>-]<<<<+>-]>>>>[-]----[>---<----]>+.[>]<<<<<[.<<]

Я очікував, що це буде набагато коротше.

Це створює "рядок", який виглядає, | (...) |і такий, який виглядає так +----(...)----+, друкуючи кожну за необхідності, зі спеціальним корпусом для os вгорі та внизу.

Потрібен інтерпретатор, який використовує 8-бітні комірки і дозволяє перейти ліворуч від комірки 0 (будь то негативні комірки або циклічно). На мій досвід, це найпоширеніші настройки за замовчуванням.

З коментарями:

,[<+<<<<+>>>>>-]<[[>>]+[<<]>>-] Get m from input; make a copy
                      Turn it into m cells containing 1 with empty cells between

<----[>---<----]      Put 67 at the beginning (again with an empty cell between)

--[>[+>>]<<[<<]>++++++]  Add 43 to every nonempty cell

>[+.>>]               Add 1 to each cell and print it

-[<+>---]<+++++++    Put 92 after the last 45 (no empty cell!)

>>--[<+>++++++]      Put 43 immediately after the 92

->---[<------->+]    Put 234 after 43

++++++++++           And 10 after that

[<++<]             Add two to the 234; 92; the empty spaces; and left of the 111

+++++[>[++++++>>]<<[<<]>-] Add 30 to each 2; the 94; and the 236

>[-]>.-<<----[>>+++<<----] Erase leftmost 32; Print 111; subtract 68 from it

--[>+<--]>---        Put 124 where the 32 was

<<<<++++++++++.,     Print a newline; override the cell with n from input

[                    n times:

  >[>+>+<<-]>[<+>-]    Make a copy of m

  >[                   m times:

    <<<<                 Look for a flag at a specific cell

    [                    If it's there:

      >>>>>>[.>>]          Go to the 43; print it and every second cell after

      <<[<<]>>-            Clear the flag

    ]

    >>>>>[.>>]           Go to the 124; print it and every second cell after

    <<[<<]>              Go back to the copy of m

  -]

  <<<<+>               Plant the flag

-]

>>>>

[-]----[>---<----]>+ Erase the 124; add 68 to 43

.[>]                 Print it; then head to the end

<<<<<[.<<] Go to the last 45; print it; then print every second cell to the left



2

Perl, 98 байт

($n,$m)=@ARGV;print$h="o"."-"x$m."o\n",((("|".(" "x$m)."|\n")x$m.$h)x$n)=~s{o(-+)o(?=\n.)}{+$1+}gr

1
Відмінна перша відповідь. Але я не бачу жодних +знаків у вашому коді, чи вважали ви, що проміжні рейки мають +знаки на кожному кінці?
Річка Рівня Св.

Дякую за дуже чудовий коментар - я повністю розставив знаки плюс! Коштує і мене небагато місця; я все ще думаю про те, як я можу це скоротити ... окрім того, щоб пропустити ($n,$m)=@ARGV;і припускати, що вони вже встановлені - не впевнений, це в дусі чи ні. Мені доведеться його подивитися.
ZILjr

Якщо в питанні не вказано інше, тут використовується правило meta.codegolf.stackexchange.com/a/2422/15599 . Ви не можете просто припустити, що змінні встановлені, але ви можете написати функцію замість програми, якщо це допоможе. Я не роблю Perl, але я вважаю, що це може врятувати вас @ARGV. Також, відповідаючи комусь, пам’ятайте, що він включив @username, щоб вони отримували сповіщення. Мені це не потрібно робити, оскільки це ваша посада.
Рівень річки Св.


1

Tcl, 187 байт

lassign $argv n w
set c 0
while { $c < [expr {($w * $n) + ($n + 2)}]} {if {[expr {$c % ($n + 1)}] == 0} {puts "o[string repeat "-" $w ]o"} else {puts "|[string repeat " " $w ]|"}
incr c}

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


1

PHP, 81 байт

Очікує 2 аргументи, передані при безпосередньому виклику команди PHP. Перший - це розмір, а другий - кількість кроків.

$R=str_repeat;echo$P="o{$R('-',$W=$argv[1])}o
",$R("|{$R(' ',$W)}|
$P",$argv[2]);

Може потребувати певних удосконалень.


0

Python 2, 94 байти

def F(n,m):a,b,c,d='o|+-';r=[a+d*m+a]+([b+' '*m+b]*m+[c+d*m+c])*n;r[-1]=r[0];print'\n'.join(r)

"Безголовки":

def F(n,m):
 # 'o---o'
 r = ['o'+'-'*m+'o']
 # ('|   |'*m+'+---+') n times
 r += (['|'+' '*m+'|']*m+['+'+'-'*m+'+'])*n
 # replace last +---+ with o---o
 r[-1] = r[0]
 print '\n'.join(r)


0

Піп -l , 35 байт

(^YsXbRLaJW'-)XbWR^('|XbRLaJ'+)WR'o

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

Пояснення

(^YsXbRLaJW'-)XbWR^('|XbRLaJ'+)WR'o
                                     a is length, b is size, s is space (implicit)
   sXb                               String containing b spaces
      RLa                            List containing a copies of that string
         JW'-                        Join on "-" and wrap the result in "-" as well
  Y                                  Necessary for operator precedence reasons
 ^                                   Split into a list of characters
(            )Xb                     String-repeat each character in the list b times
                                     This list represents the central columns of the ladder

                    '|Xb             String containing b pipe characters
                        RLa          List containing a copies of that string
                           J'+       Join on "+"
                   (          )WR'o  Wrap in "o"
                  ^                  Split into a list of characters
                                     This list represents the outer columns of the ladder

                WR                   Wrap the left list in the right list, vectorizing

Деякі інші версії

Я спробував багато різних підходів, намагаючись зловити Pyth ...

[Y'-XbWR'o;@>(sXbWR'|RLbPE'-XbWR'+RL:a)y]  41
Y^(t**b.1*:t**bX--a.1)" --"@yXbWR"|o+"@y   40
Y'|XbRLaJ'+YyWR'o;Z:sXbRLaJW'-RLbPEyAEy    39
t**:b(" |-o-+"<>2)@_@^t.1M$*Y[ttXa-1].1    39
J*Z:sXbRLaJW'-RLbWR:^('|XbRLaJ'+)WR'o      37
Y^$*Y[t**:btXa-1].1" --"@yXbWR"|o+"@y      37

Мені особливо подобаються t**bті, які використовують математику для створення вертикального шаблону сходів:

        b           Size; e.g. 3
    t               Preset variable for 10
     **:            Set t to t**b (e.g. 1000)
           a        Length; e.g. 3
            -1      2
         tX         String-repeat (the new value of) t 2 times: 10001000
   [          ]     Put t and the above into a list: [1000; 10001000]
               .1   Append 1 to both of them: [10001; 100010001]
$*(              )  Fold on multiplication: 1000200020001

1000200020001Потім можна використовувати для генерації шаблонів o|||+|||+|||oі - - - -, які роблять вгору по сходах. На жаль, я не міг зробити такий підхід коротшим, ніж підключення / обгортання.

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