Visualisez la longue addition avec l'art ASCII

13

Totalement pas inspiré par Visualize long division with ASCII art ;)

Votre travail consiste à montrer l'addition à main longue avec l'art ASCII. Vous résolvez l'addition à long terme en additionnant les colonnes de droite à gauche, en plaçant la valeur de celles qui sont placées dans le résultat et en portant la place des dizaines en haut de la colonne suivante.

Contribution

L'entrée peut venir dans n'importe quel format que vous voulez, aussi longtemps que vous prenez de 2 à 9 chiffres en entrée.

Production

Le formatage ici correspond probablement à la façon dont vous l'avez appris à l'école:

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

Vous pouvez avoir à peu près n'importe quelle quantité d'espace blanc de fin que vous voulez ici;)

Exemples

50, 50

1
 50
+50
---
100


1651, 9879

1111
 1651
+9879
-----
11530

6489789, 9874, 287

   1122
 6489789
    9874
+    287
--------
 6499950
J Atkin
la source
Visualisez une longue soustraction avec l'art ASCII: Venez directement chez vous en 6 mois
CalculatorFeline
Pas tout à fait, c'est sur ma liste;)
J Atkin
1
En fait, on m'a appris à mettre la ligne de transport sous le résultat.
Neil
1
Comment devons-nous gérer 9+9+9+9+9+9+9+9+9+9+9+9+9?
Downgoat
1
@Downgoat ... you take from 2 to 9 numbers as input...
PurkkaKoodari

Réponses:

5

Pyth, 59 58 octets

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

Essayez-le en ligne. Suite de tests.

Bien trop long. Devrait jouer au golf plus.

Explication

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
la source
1

Lot, 326 octets

Le nombre d'octets ne comprend pas d'explication, bien sûr.

@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 +)
Neil
la source
0

JavaScript (ES6), 199 octets

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-)/,`+`)

Où le premier \nreprésente un caractère de nouvelle ligne littéral, tandis que le second est une séquence d'échappement d'expression rationnelle à deux caractères. Explication:

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 -

Le calcul de report fonctionne en prenant le chiffre total, en préfixant 90, en soustrayant tous les chiffres de la valeur d'entrée dans cette colonne et en prenant le résultat modulo 10. (Le préfixe est 90plutôt que de 9sorte que la colonne de tête génère un espace de report vierge.)

Neil
la source