Визуализируйте длинное дополнение с искусством ASCII

13

Совершенно не вдохновлен визуализировать долгое разделение с искусством ASCII ;)

Ваша задача - показать сложение длинных рук с помощью ASCII art. Вы решаете ручное добавление, складывая столбцы справа налево, помещая значение тех мест, которые находятся в результате, и перенося десятки в верхнюю часть следующего столбца.

вход

Ввод может происходить в основном в любом формате, который вы хотите, если вы берете от 2 до 9 чисел.

Выход

Форматирование здесь, скорее всего, соответствует тому, как вы узнали это в школе:

carry row
 number1 
 number2
     ...
+   numX
--------
  result

Вы можете иметь практически любое количество пробелов, которое вам нужно;)

Примеры

50, 50

1
 50
+50
---
100


1651, 9879

1111
 1651
+9879
-----
11530

6489789, 9874, 287

   1122
 6489789
    9874
+    287
--------
 6499950
Дж Аткин
источник
Визуализируйте длинное вычитание с помощью ASCII art: прямо к вам через 6 месяцев
CalculatorFeline
Не совсем, это в моем списке;)
J Аткин
1
На самом деле меня учили ставить строку переноса под результатом.
Нил
1
Как мы должны обращаться 9+9+9+9+9+9+9+9+9+9+9+9+9?
Вниз
1
@ Downgoat ... you take from 2 to 9 numbers as input...
PurkkaKoodari

Ответы:

5

Pyth, 59 58 байт

L.[dJhl`eSQ`b:jk_.u/+NsYT.t_MjRTQ00\0djbyMPQXyeQ0\+*J\-ysQ

Попробуйте онлайн. Тестирование.

Слишком долго. Должен гольф больше.

объяснение

L                  helper function y = lambda b:
        eSQ          largest number in input
      l`             length as string
     h               increment
    J                save to J
 .[d       `b        pad argument with spaces to that length

                             carry row:
                jRTQ           each input to base 10
              _M               reverse each result
            .t      0          transpose, padding with zeroes
    .u               0         cumulative reduce from 0:
         sY                      sum digits of column
       +N                        add previous carry
      /    T                     floor-divide by 10
   _                           reverse
 jk                            join by ""
:                     \0d      replace 0 by space

          number rows:
    PQ      all input numbers but last one
  yM        pad to correct length
jb          print on separate lines

           last number row:
  eQ         last input number
 y           pad to correct length
X   0\+      change first char to +

        separator row:
 J        width of input (saved in helper)
* \-      that many dashes

       result row:
 sQ      sum of inputs
y        pad to correct length
PurkkaKoodari
источник
1

Пакетный, 326 байт

Конечно, в число байтов не входит объяснение.

@echo off
set t=%*                            Get the space separated parameters
set t=%t: =+%                       Change the spaces into + signs
set/at=%t%,l=p=1                    Add together, and initialise length and power
set c=                              Carry string
set d=-                             Dash string
:l                                  Loop though each power of 10
set/al+=1,p*=10,s=t/p               Divide the total by the power
for %%n in (%*)do set/as-=%%n/p     Subtract each parameter divided
set c=%s%%c%                        Anything left must have been carried
set d=-%d%                          Add a - to the line of dashes
if %p% leq %t% goto l               Keep going until we run out of powers
echo(%c:0= %                        Delete any zeros in the carry and output it
:i                                  Loop through each parameter
set n=%d:-= %%1                     Pad it with a whole bunch of spaces
call set n=%%n:~-%l%%%              Extract the rightmost characters
if "%2"=="" set n=+%n:~1%           Insert a + before the last parameter
echo %n%                            And output it
shift                               Move to the next parameter
if not "%1"=="" goto i              Until they are all consumed
echo %d%                            Output the line of dashes
echo  %t%                           Output the total (with an indent for the +)
Нил
источник
0

JavaScript (ES6), 199 байт

a=>[[...t=` `+a.reduce((t,n)=>t+n)].map((_,i)=>a.reduce((c,n)=>c-n[i],90+t[i])%10||` `),a=a.map(n=>(` `.repeat(l=t.length)+n).slice(-l))).join``,...a,`-`.repeat(l),t].join`\n`.replace(/ (?=.*\n-)/,`+`)

Где первый \nпредставляет буквенный символ новой строки, а второй представляет собой двухсимвольную escape-последовательность регулярного выражения. Объяснение:

a=>[                            Accept an array of numbers
 [...                           Split the total into digits
  t=` `+a.reduce((t,n)=>t+n)    Calculate the total and add a space
 ].map((_,i)=>a.reduce((c,n)=>  For each column
  c-n[i],90+t[i])               Subtract the column from the total
  %10||` `),                    Deduce the carry that was needed
  a=a.map(n=>                   For each input value
   (` `.repeat(l=t.length)+n)   Pad to the length of the total
    .slice(-l))                 Remove excess padding
 ).join``,                      Join the carries together
 ...a,                          Append the padded input values
 `-`.repeat(l),                 Append the dividing line
 t].join`\n`                    Append the total and join together
  .replace(/ (?=.*\n-)/,`+`)    Insert the + on the line above the -

Расчет переноса выполняется путем взятия общей цифры, префикса 90, вычитания всех цифр входного значения в этом столбце и получения результата по модулю 10. (Префикс 90скорее 9так, что передний столбец генерирует пустое пространство переноса.)

Нил
источник