Alice , 23 bytes
/oRe./'+Ao
\I*tI&0-R$@/
Pruébalo en línea!
La entrada debe estar separada por salto de línea con el número en la primera línea y el ancho en la segunda.
Explicación
/...
\...@/
Este es el marco habitual para programas lineales en modo ordinal. El único inconveniente en este caso es este bit:
.../...
...&...
Esto hace que la IP entre en modo Cardinal verticalmente y se ejecute solo &
en modo Cardinal antes de reanudarse en modo Ordinal.
Al desplegar el flujo de control en zigzag, se obtiene:
IRt.&'-A$o*eI/&/0+Ro@
I Read the first line of input (the value) as a string.
R Reverse the string.
t. Split off the last character and duplicate it.
& Fold the next command over this string. This doesn't really do anything,
because the string contains only one character (so folding the next
command is identical to executing it normally).
'- Push "-".
A Set intersection. Gives "-" for negative inputs and "" otherwise.
$o If it's "-", print it, otherwise it must have been a digit which we
leave on the stack.
* Join the digit back onto the number. If the number was negative, this
joins the (absolute value of the) number to an implicit empty string,
doing nothing.
e Push an empty string.
I Read the width W.
/&/ Iterate the next command W times.
0 Append a zero. So we get a string of W zeros on top of the absolute
value of the input number.
+ Superimpose. This takes the character-wise maximum of both strings
and appends extraneous characters from the longer string. Since the
string of zeros can never be larger than the digits in the input,
the input itself will be uneffected, but extraneous zeros are appended,
padding the string to the required length.
R Reverse the result.
o Print it.
@ Terminate the program.
Aquí hay dos alternativas, también en 23 bytes, que usan Cardinal H
( abs ) para deshacerse de -
:
/R.I&0-RoH
\Ie#\'+Ao\@/
/R.H#/.+Xo
\Ie\I&0QRo@/
En principio, este es un comando más corto, pero &
no cabe en una posición donde hay una cadena de 1 carácter en la pila, por lo que debemos omitirla con a #
.