Вступление
Большинство из вас знакомы с алгоритмом сортировки слиянием для сортировки списка чисел. Как часть алгоритма, каждый пишет вспомогательную функцию, merge
которая объединяет два отсортированных списка в один отсортированный список. В Python-подобном псевдокоде функция обычно выглядит примерно так:
function merge(A, B):
C = []
while A is not empty or B is not empty:
if A is empty:
C.append(B.pop())
else if B is empty or A[0] ≤ B[0]:
C.append(A.pop())
else:
C.append(B.pop())
return C
Идея состоит в том, чтобы отбрасывать меньшие из первых элементов A
и B
до тех пор, пока оба списка не станут пустыми, и собрать результаты в C
. Если A
и B
оба отсортированы, то так и есть C
.
И наоборот, если C
это отсортированный список, и мы разбиваем его на любые две подпоследовательности A
и B
, то A
и B
также сортируются и merge(A, B) == C
. Интересно, что это не обязательно имеет место, если C
не отсортировано, что приводит нас к этой проблеме.
вход
Ваш ввод - это перестановка первых 2*n
неотрицательных целых чисел [0, 1, 2, ..., 2*n-1]
для некоторых n > 0
, представленная в виде списка C
.
Выход
Ваш вывод должен быть истинным значением, если существует два списка A
и такой B
длины , и иначе ложным значением. Поскольку входные данные не содержат дубликатов, вам не нужно беспокоиться о том, как в функции нарушаются связи .n
C == merge(A, B)
merge
Правила и бонусы
Вы можете написать либо функцию, либо полную программу. Побеждает меньшее количество байтов, и стандартные лазейки запрещены.
Обратите внимание, что вы не обязаны вычислять списки A
и B
в случаях «да». Однако, если вы действительно выводите списки, вы получаете бонус -20% . Чтобы получить этот бонус, вы должны вывести только одну пару списков, а не все возможности. Чтобы облегчить получение этого бонуса в строго типизированных языках, разрешено выводить пару пустых списков в случаях «нет».
Грубое принуждение не запрещено, но есть бонус -10% для вычисления всех последних четырех тестовых случаев в общей сложности менее чем за 1 секунду.
Тестовые случаи
В экземплярах «да» дается только один возможный вывод.
[1,0] -> False
[0,1] -> [0] [1]
[3,2,1,0] -> False
[0,3,2,1] -> False
[0,1,2,3] -> [0,1] [2,3]
[1,4,0,3,2,5] -> False
[4,2,0,5,1,3] -> [4,2,0] [5,1,3]
[3,4,1,2,5,0] -> [4,1,2] [3,5,0]
[6,2,9,3,0,7,5,1,8,4] -> False
[5,7,2,9,6,8,3,4,1,0] -> False
[5,6,0,7,8,1,3,9,2,4] -> [6,0,8,1,3] [5,7,9,2,4]
[5,3,7,0,2,9,1,6,4,8] -> [5,3,7,0,2] [9,1,6,4,8]
[0,6,4,8,7,5,2,3,9,1] -> [8,7,5,2,3] [0,6,4,9,1]
[9,6,10,15,12,13,1,3,8,19,0,16,5,7,17,2,4,11,18,14] -> False
[14,8,12,0,5,4,16,9,17,7,11,1,2,10,18,19,13,15,6,3] -> False
[4,11,5,6,9,14,17,1,3,15,10,12,7,8,0,18,19,2,13,16] -> [4,17,1,3,15,10,12,7,8,0] [11,5,6,9,14,18,19,2,13,16]
[9,4,2,14,7,13,1,16,12,11,3,8,6,15,17,19,0,10,18,5] -> [9,4,2,16,12,11,3,8,6,15] [14,7,13,1,17,19,0,10,18,5]
(K[0], Q-K[0])
вы можете печатать(K[0], K[-1])
. Я не знаю, даст ли это экономию, хотя.K[::len(K)-1]
.GolfScript (35 * 0,9 = 31,5)
Онлайн демо довольно медленно: на моем компьютере, он запускает все тесты в рамках 0,04 секунды, поэтому я требую снижения на 10%.
объяснение
источник
APL,
625044 * 90% = 39,6Попробуй это здесь.
источник