Сегодня мы будем вычислять наиболее эффективную двоичную функцию. Более конкретно, мы будем вычислять функцию, которая при создании выражения на основе применения функции к постоянному входу 0 или ее собственному выходу может представлять все положительные целые числа с кратчайшими возможными выражениями, уделяя большее внимание меньшим целым числам.
Эта функция построена следующим образом:
Для каждого целого числа, начиная с 1 и восходящего, выберите самое короткое выражение, которому мы еще не присвоили вывод, и сделайте это целое число выводом этого выражения. Связи в длине выражения будут нарушены меньшим левым аргументом, а затем меньшим правым аргументом. Вот как это работает:
Первоначально 1 не назначен. Самое короткое неназначенное выражение есть
f(0, 0), поэтому мы установим его на 1.Теперь 2 не назначено. Самые короткие неназначенные выражения:
f(f(0, 0), 0)=f(1, 0)иf(0, f(0, 0))=f(0, 1). Связи разрываются в сторону меньшего левого аргумента, так чтоf(0, 1) = 2.Самое короткое неназначенное оставшееся выражение -
f(f(0, 0), 0)=f(1, 0), поэтомуf(1, 0) = 3.Теперь у нас нет выражений, у которых всего 2
fс и 30с, поэтому нам нужно добавить еще по одному для каждого. Разрывая связи левым аргументом, затем правый аргумент, мы получаемf(0, 2) = 4, так какf(0, f(0, f(0, 0))) = f(0, f(0, 1)) = f(0, 2).Продолжая, у нас есть
f(0, 3) = 5,f(1, 1) = 6,f(2, 0) = 7,f(3, 0) = 8,f(0, 4) = 9, ...
Вот таблица, которую я заполнил для первых нескольких значений:
0 1 2 3 4 5 6 7 8
/---------------------------
0| 1 2 4 5 9 10 11 12 13
1| 3 6 14 15 37 38 39 40 41
2| 7 16 42 43
3| 8 17 44 45
4| 18 46
5| 19 47
6| 20 48
7| 21 49
8| 22 50
Другой способ взглянуть на это состоит в том, что каждый выход имеет размер, равный сумме размеров его входов плюс один. Таблица заполняется в порядке увеличения размера выходных данных, связи прерываются при минимизации левого и правого входов.
Ваша задача состоит в том, чтобы при вводе двух неотрицательных целых чисел вычислить и вывести значение этой функции. Это код гольф. Самое короткое решение, в байтах, выигрывает. Стандартные лазейки запрещены.
((0, (0, (0, 0))), 0)лексикографически меньше, чем (((0, 0), 0), (0, 0)), однако последний имеет меньшую левую сторону.