Имея упорядоченный список чисел (возможно, с ведущими нулями), расположите числа по вертикали, затем позвольте всем нулям опуститься до самого дна, а все выступы упадут до самого нижнего открытого отверстия. Выведите полученные целые числа, удалив начальные нули.
Работал пример
Скажем, нам дали следующее:
['0000312941295', '239124000124581598', '32852353800451258', '10235923505185190', '1491359102149']
Сначала мы расположим это вертикально:
0000312941295
239124000124581598
32852353800451258
10235923505185190
1491359102149
Затем, столбец за столбцом, опускайте нули «через» другие числа, чтобы они располагались внизу, и «подталкивали» другие числа вверх. Это приведет к тому, что первые два шага будут следующими:
2000312941295
339124000124581598
12852353800451258
10235923505185190
0491359102149
^
2300312941295
329124000124581598
14852353800451258
10235923505185190
0091359102149
^
2390312941295
328124000124581598
14252353800451258
10935923505185190
0001359102149
^
...
2391312941295
328524538124581598
14232323525451258
10915991001185190
0000350000049
^
Затем отбросьте все выступы, как будто гравитация тянет их вниз, как песок.
2391312941295
3285245381245 1598
14232323525458258
10915991001181190
00003500000495
^
2391312941295
3285245381245 598
14232323525458158
10915991001181290
000035000004951
^
...
2391312941295
3285245381245
14232323525458159
10915991001181258
000035000004951908
^
Наконец, выведите эти числа, удалив начальные нули. Для нашего сработавшего примера выведите:
[2391312941295, 3285245381245, 14232323525458159, 10915991001181258, 35000004951908]
Для другого примера предположим ввод [1234000,12345678,1234,12340608,12341234]
.
1234000
12345678
1234
12340608
12341234
Сбросьте нули:
1234
12345678
1234163
12340208
12340004
Удалите оставшиеся нависающие цифры:
1234
1234567
12341638
12340208
12340004
Выход есть [1234, 1234567, 12341638, 12340208, 12340004]
.
правила
- Ввод может содержать начальные нули. Выход не должен содержать начальных нулей.
- Если применимо, вы можете предположить, что ввод / вывод будет соответствовать целочисленному типу вашего языка.
- Вход и выход могут быть заданы любым удобным способом. .
- Либо полная программа или функция приемлемы. Если функция, вы можете вернуть вывод, а не распечатать его.
- Стандартные лазейки запрещены.
- Это код-гольф, поэтому применяются все обычные правила игры в гольф, и выигрывает самый короткий код (в байтах).
and all overhangs drop to the bottom-most open slot
был хорошим решением для моего сломанного вызова :).
. 1234
сильно отличается от вывода 1234
.
14232323525458159
до14232323525458160
)