Построить 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 во всех четырех углах.

  • Границы между квадратами сливаются вместе, поэтому две строки подряд +--...--+сливаются в одну.

  • Углы всей лестницы заменяются персонажем o.

  • Вы можете при желании вывести завершающий перевод строки.

Длина лестницы ( n ) всегда будет ≥ 2, а размер ( м ) всегда будет ≥ 1.

Входные данные могут быть приняты в виде строки, разделенной пробелами / запятыми, массива / списка / и т. Д. Или двух функций / командной строки / и т. Д. аргументы. Аргументы могут быть приняты в любом порядке, наиболее удобном / наиболее подходящем для игры в гольф.

Поскольку это , выигрывает самый короткий код в байтах.

Совет: Приведенные выше примеры также можно использовать в качестве тестовых случаев.


Нужно ли сначала брать длину, потом размер?
РК.

@RK. Вы можете взять их в любом удобном для вас порядке.
Дверная ручка

1
Может ли быть ведущий перевод строки?
Конор О'Брайен

1
@ C'O'Bʀɪᴇɴ Э-э-э ... Я собираюсь пойти без этого.
Ручка двери

1
Хорошо: P Это стоило того.
Конор О'Брайен

Ответы:


4

Pyth, 34 байта

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

Тестирование

Принимает аргументы newline, разделенные на STDIN.

Использует вспомогательную функцию, :которая строит каждый тип вертикальной строки из трех символов, затем реплицирует при необходимости, транспонирует и объединяет на новых строках.


11

Руби, 71

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

разряженный в тестовой программе

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

@ 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
Добро пожаловать в Программирование Пазлов и Code Golf! В вашем коде есть много пробелов, которые вы можете удалить, чтобы сократить его. Если вы хотите больше помочь в игре, вы можете проверить Советы по игре в гольф на 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)

Это функция, которая принимает два целых числа и возвращает строку.

Ungolfed:

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. Увы, я думаю, это просто словесный язык.

Сначала берется длина ввода, затем размер. Принимает ввод в виде байтовых значений, например: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

Pure Bash, 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]

Изменить: @ Кристиан Ирван нашел 3 байта. Благодарность!


Сопоставление паттернов за -1 балл m=init$[1..l]>>("|"!" "<$u)++["+"!"-"]=>(_:m)=[1..l]>>["+"!"-"]++("|"!" "<$u)
Akangka

Удивительно _:m=[1..l]>>["+"!"-"]++("|"!" "<$u)работает
Akangka

@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
Отличный первый ответ. Но я не вижу никаких +признаков в вашем коде. Считаете ли вы, что промежуточные ступени имеют +знаки на каждом конце?
Уровень Река St

Спасибо за очень хорошо сформулированный комментарий - я полностью расставил плюсы! Мне тоже стоило немного места; все еще думая о том, как я могу сократить это ... кроме того, что опущу ($n,$m)=@ARGV;и предположим, что они уже установлены - не уверен, в духе ли это Я должен это посмотреть.
ZILjr

Если в вопросе не указано иное, здесь используется правило meta.codegolf.stackexchange.com/a/2422/15599 . Вы не можете просто предполагать, что переменные установлены, но вы можете написать функцию вместо программы, если это поможет. Я не делаю Perl, но я предполагаю, что это может спасти вас @ARGV. Кроме того, при ответе кому-то не забудьте указать @username, чтобы он получал оповещение. Мне не нужно это делать, так как это ваш пост.
Уровень Река St


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)

'Ungolfed':

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

Некоторые другие версии

Я пробовал много разных подходов, пытаясь поймать Пита ...

[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.