Alice , 23 bytes
/oRe./'+Ao
\I*tI&0-R$@/
Experimente online!
A entrada deve ser separada pela alimentação de linha com o número na primeira linha e a largura na segunda.
Explicação
/...
\...@/
Essa é a estrutura usual para programas lineares no modo Ordinal. O único problema neste caso é este bit:
.../...
...&...
Isso faz com que o IP entre no modo Cardinal verticalmente e execute apenas o &
modo Cardinal antes de continuar no modo Ordinal.
O desdobramento do fluxo de controle em zigue-zague fornece:
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.
Aqui estão duas alternativas, também em 23 bytes, que usam Cardinal H
( abs ) para se livrar de -
:
/R.I&0-RoH
\Ie#\'+Ao\@/
/R.H#/.+Xo
\Ie\I&0QRo@/
Em princípio, esse comando é mais curto, mas &
não se encaixa em uma posição em que haja uma cadeia de 1 caractere na pilha; portanto, precisamos ignorá-lo com a #
.