Алиса , 23 байта
/oRe./'+Ao
\I*tI&0-R$@/
Попробуйте онлайн!
Ввод должен быть разделен переводом строки с номером в первой строке и шириной во второй.
объяснение
/...
\...@/
Это обычная структура для линейных программ в обычном режиме. Единственный улов в этом случае - этот бит:
.../...
...&...
Это заставляет IP переходить в кардинальный режим по вертикали и выполнять только &
в кардинальном режиме, прежде чем возобновить в обычном режиме.
Развернув зигзагообразный поток управления, вы получите:
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.
Вот две альтернативы, также по 23 байта, которые используют Cardinal H
( abs ), чтобы избавиться от -
:
/R.I&0-RoH
\Ie#\'+Ao\@/
/R.H#/.+Xo
\Ie\I&0QRo@/
В принципе, это команда короче, но &
она не вписывается в позицию, где в стеке находится строка из 1 символа, поэтому мы должны пропустить ее с помощью символа a #
.