Введение
Давайте определим троичную функцию как функцию из трехэлементного набора, S = {0,1,2}который она себе представляет: она ассоциируется с каждым элементом Sдругого элемента S. Одним из примеров троичной функции fявляется
f(0) = 0; f(1) = 2; f(2) = 0
Существует ровно 27 различных троичных функций, и мы представляем их целыми числами от 0 до 26: функция fкодируется как f(0) + 3*f(1) + 9*f(2). Пример функции выше закодирован как номер 6.
Мы можем применять две троичные функции fи gпоследовательно, и если f(g(k)) == g(f(k))выполняется для всех kв S, то функции коммутируют . Ваша задача - проверить, так ли это.
вход
Ваши входные данные - это два целых числа в диапазоне от 0 до 26. Они представляют две троичные функции fи g. Входные данные должны быть приняты в десятичном, двоичном или унарном (строка 1с) формате.
Выход
Ваш вывод является истинным значением, если fи gкоммутируют, и ошибочным значением, если они этого не делают. Вы не можете предполагать, что входы упорядочены.
Примеры
Рассмотрим входы 5 и 16. Они кодируют троичные функции
f(0) = 2; f(1) = 1; f(2) = 0
g(0) = 1; g(1) = 2; g(2) = 1
У нас есть f(g(1)) == f(2) == 0и g(f(1)) == g(1) == 2, поэтому, fи gне коммутируют, и правильный вывод ложный.
С другой стороны, входы 3 и 10 кодируют троичные функции
f(0) = 0; f(1) = 1; f(2) = 0
g(0) = 1; g(1) = 0; g(2) = 1
и это может быть проверено, что f(g(k)) == g(f(k))верно для всех kв S. Тогда правильный вывод правдив.
Вот таблица всех возможных входных данных 27 × 27 с +пометкой истинного и -ложного вывода:
+ - - + - - + - - + - - + - - + - - + - - + - - + - -
- + - - - - - - - - - - + - - - - - - - - + - - - - -
- - + - - - - - - - - - - - - - - - - - - + - - + - -
+ - - + - - - - - - + - - + - - - - + - - + - - - - -
- - - - + - - - - - - - - + - - - - - - - + - - - - -
- - - - - + - - - - - - - + - - - - - - - + - - - - -
+ - - - - - + - - - - - - - - - - - - - - + - - - - -
- - - - - - - + - - - + - - - - - - - - - + - - - - -
- - - - - - - - + - - - - - - - - - + - - + - - - - -
+ - - - - - - - - + - - - - - - - - - - - + - - - - -
- - - + - - - - - - + - - - - - - - - - - + - - - - -
- - - - - - - + - - - + - - - - - - - - - + - - - - -
+ + - - - - - - - - - - + + - - - - - - - + + - - - -
- - - + + + - - - - - - + + + - - - - - - + + + - - -
- - - - - - - - - - - - - + + - - - - - - + - - - - -
+ - - - - - - - - - - - - - - + - - - - - + - - - - -
- - - - - - - - - - - - - - - - + - - - - + - + - - -
- - - - - - - - - - - - - - - - - + - - - + + - - - -
+ - - + - - - - + - - - - - - - - - + - - + - - - - +
- - - - - - - - - - - - - - - - - - - + - + - - - - +
- - - - - - - - - - - - - - - - - - - - + + - - - - +
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
- - - - - - - - - - - - + + - - - + - - - + + - - - +
- - - - - - - - - - - - - + - - + - - - - + - + + - +
+ - + - - - - - - - - - - - - - - - - - - + - + + - +
- - - - - - - - - - - - - - - - - - - - - + - - - + +
- - - - - - - - - - - - - - - - - - + + + + + + + + +
Правила и оценки
Вы можете написать полную программу или функцию. Побеждает меньшее количество байтов, и стандартные лазейки запрещены.