Wizualizuj długie mnożenie ze sztuką ASCII

12

Wyzwanie

Napisz program, który pobiera dwie liczby całkowite ze standardowego wejścia oddzielone przecinkiem, a następnie drukuje wizualizację długiego mnożenia tych dwóch liczb całkowitych na standardowe wyjście.

Na przykład:

Wejście

14, 11

Wyjście programu

     14
    x11
   _____
     14
    14
  ______
    154

Wejście

-7, 20

Wyjście programu

     -7
    x20
   _____
     00
    14
   _____
   -140

Zakładaj zawsze prawidłowe dane wejściowe i liczby w zakresie [-999, 999]

Kryteria wygranej

Najkrótszy kod wygrywa!

Averroes
źródło
Poprawiono spójność z codegolf.stackexchange.com/questions/1624/…
Peter Taylor

Odpowiedzi:

3

Perl, 108 znaków

Najlepsze z rasy 108 znaków rozwiązanie, zawierające kilka pomysłów z Orabig.

($x,$y)=<>=~/[-\d]+/g;printf"%7s
",$_ for$x,x.$y,"-"x7,(map{abs($x*$_).$"x$i++}reverse$y=~/\d/g),"-"x7,$x*$y

Wcześniej 139 znaków char

sub P{sprintf"%*d",@_}
($x,$y)=<>=~/[^,]+/g;$,=$/;
print P(7,$x),"  x".P(4,$y),"-"x7,(map{P 7-$i++,abs$_*$x}reverse$y=~/\d/g),
"-"x7,P 7,$x*$y
tłum
źródło
/ ja kłaniam się w stosunku ... Nie widziałem możliwości włączenia mapy do części printf. A $y=~/\d/gsztuczka była sprytna
Orabîg
5

Mathematica 213 217 197 193 186 184 193 184 177

Kod

a_~g~b_ := 
With[{e = IntegerDigits@b}, Column[Flatten@{a, UnderBar["x " <> IntegerString[b]], 
Table[Row @@ {PadRight[{a Reverse[e][[i]]}, i, " "]}, {i, Length@e}], OverBar[a b]}, 
Alignment -> Right]]

Stosowanie

g[845, 921]

zwielokrotniać

DavidC
źródło
Na pewno IntegerString[921]masz na myśli IntegerString[b]?
David Zhang,
Tak, dobry chwyt!
DavidC
Myślę, że specyfikacja pozwala na usunięcie przestrzeni w "x ".
Decıʇǝɥʇuʎs
Masz rację. Postanowiłem go zostawić, ponieważ wyglądał lepiej (i tak i tak nie zamierzałem mieć najkrótszego kodu).
DavidC
1

Python, 174 170:

a,b=input();r,s=str(a),str(b);h=len(r+s)*'-';print'\n'.join(["%9s\n%9s\n%9s"%(r,'x'+s,h)]+["%%%ii"%(9-i)%(int(d)%10*a)for i,d in enumerate(s[::-1])]+["%9s\n%9i"%(h,a*b)])

Zastosowanie: dokładnie zgodnie z żądaniem, uruchom i wprowadź wartości na standardowym wejściu.

Aby zobaczyć bieganie: http://ideone.com/S8xNb

Wynik:

     1234
    x5678
 --------
     9872
    8638
   7404
  6170
 --------
  7006652

Dzięki fabiocerqueira i beary605 oraz David Carraher

olivecoder
źródło
Możesz usunąć 4 znaki białych znaków: print '\n'-> print'\n', 10*a) for i,d in enumerate-> 10*a)for i,d in enumerate, "%9s\n%9i" % (h,a*b)->"%9s\n%9i"%(h,a*b)
beary605
1

Python, 145, kolejna odpowiedź z nieco innym wyjściem.

Kod

a,b=input();h=6*'-';print'\n'.join(["%6i\nx%5i\n%s"%(a,b,h)]+["%%%ii"%(6-i)%(int(d)%10*a)for i,d in enumerate(str(b)[::-1])]+["%s\n%6i"%(h,a*b)])

Stosowanie

zgodnie z życzeniem

Wynik

   999
x  999
------
  8991
 8991
8991
------
998001

Aby zobaczyć bieganie: http://ideone.com/mdR18

olivecoder
źródło
1

Perl , 157 151 150 144 141 133 znaków:

($x,$y)=<>=~/[-\d]+/g;map{$z=~s/z/ z/g;$z=(abs$x*$_)."z$z"}split//,abs$y;map{printf"%6s
",$_}$x,"x$y",$b="-"x6,(split/z/,$z),$b,$x*$y

Stosowanie :

>echo "-123, 456" | perl mult.pl
   -123
   x456
-------
    738
   615
  492
-------
 -56088
Orabin
źródło
Miałem pomysł dziś rano: używając printf, poprawiłem swoje rozwiązanie o 8 znaków :)
Orabîg