Dada uma lista ordenada de números (possivelmente com zeros à esquerda), organize os números verticalmente e deixe todos os zeros caírem até o fundo e todas as saliências caírem no slot mais aberto. Produza os números inteiros resultantes, removendo os zeros à esquerda.
Exemplo Trabalhado
Digamos que recebemos o seguinte como entrada:
['0000312941295', '239124000124581598', '32852353800451258', '10235923505185190', '1491359102149']
Primeiro, organizamos verticalmente:
0000312941295
239124000124581598
32852353800451258
10235923505185190
1491359102149
Em seguida, coluna a coluna, solte os zeros "através" dos outros números para que eles fiquem embaixo e "empurre" os outros números para cima. Isso resultaria nos dois primeiros passos da seguinte maneira:
2000312941295
339124000124581598
12852353800451258
10235923505185190
0491359102149
^
2300312941295
329124000124581598
14852353800451258
10235923505185190
0091359102149
^
2390312941295
328124000124581598
14252353800451258
10935923505185190
0001359102149
^
...
2391312941295
328524538124581598
14232323525451258
10915991001185190
0000350000049
^
Em seguida, solte todas as saliências como se a gravidade as estivesse puxando para baixo como areia.
2391312941295
3285245381245 1598
14232323525458258
10915991001181190
00003500000495
^
2391312941295
3285245381245 598
14232323525458158
10915991001181290
000035000004951
^
...
2391312941295
3285245381245
14232323525458159
10915991001181258
000035000004951908
^
Finalmente, produza esses números, removendo os zeros à esquerda. Para o nosso exemplo trabalhado, output:
[2391312941295, 3285245381245, 14232323525458159, 10915991001181258, 35000004951908]
Para outro exemplo, suponha a entrada de [1234000,12345678,1234,12340608,12341234]
.
1234000
12345678
1234
12340608
12341234
Solte os zeros:
1234
12345678
1234163
12340208
12340004
Solte os demais dígitos pendentes:
1234
1234567
12341638
12340208
12340004
Saída é [1234, 1234567, 12341638, 12340208, 12340004]
.
Regras
- A entrada pode conter zeros à esquerda. A saída não deve conter zeros à esquerda.
- Se aplicável, você pode supor que a entrada / saída caiba no tipo Inteiro nativo do seu idioma.
- A entrada e saída podem ser fornecidas por qualquer método conveniente .
- Um programa completo ou uma função são aceitáveis. Se uma função, você pode retornar a saída em vez de imprimi-la.
- As brechas padrão são proibidas.
- Isso é código-golfe, portanto todas as regras usuais de golfe se aplicam e o código mais curto (em bytes) vence.
and all overhangs drop to the bottom-most open slot
foi uma boa solução para o meu desafio quebrado :).
. 1234
é muito diferente da saída 1234
.
14232323525458159
para14232323525458160
)