Quintopia опубликовала здесь задачу по вычислению многочленных коэффициентов (часть текста здесь скопирована оттуда). Есть забавный алгоритм для вычисления коэффициентов многочлена mod 2.
Учитывая список чисел, k 1 , k 2 , ..., k m , выведите остаток множителя:
приведенного по модулю 2. Следующий алгоритм делает это эффективно: для каждого к я , вычислить двоичное разложение к я , то есть, найти в Ij таким образом, что каждая IJ либо 1 , либо 0 и
Если существует такое j, что a rj = a sj = 1 для r ≠ s, то ассоциированный полиномиальный коэффициент mod 2 равен 0, в противном случае полиномиальный коэффициент mod 2 равен 1.
задача
Напишите программу или функцию, которая принимает m чисел, k 1 , k 2 , ..., k m , и выводит или возвращает соответствующий коэффициент многочлена. Ваша программа может дополнительно принять m в качестве дополнительного аргумента, если это необходимо.
Эти числа могут быть введены в любом понравившемся формате, например, сгруппированы в списки или закодированы в унарном виде, или что-либо еще, при условии, что фактическое вычисление коэффициента многочлена выполняется вашим кодом, а не процессом кодирования.
Вывод может быть любым истинным значением, если коэффициент многочлена нечетен, и любым значением Ложь, если коэффициент многочлена четен.
Встроенные модули, предназначенные для вычисления коэффициента многочлена, не допускаются.
Применяются стандартные лазейки.
счет
Это код гольф: выигрывает самое короткое решение в байтах.
Примеры:
Чтобы найти мультиномиальный коэффициент 7, 16 и 1000, мы двоично расширяем каждый из них:
Поскольку ни один столбец не имеет более одного 1, коэффициент многочлена нечетен, и поэтому мы должны вывести что-то правдивое.
Чтобы найти коэффициент многочлена 7, 16 и 76, мы двоично разлагаем каждый из них:
Так как 76 и 7 имеют 4 в двоичном разложении, коэффициент многочлена является четным, и поэтому мы выводим значение Фолси.
Тестовые случаи:
Input: [2, 0, 1]
Output: Truthy
Input: [5,4,3,2,1]
Output: Falsey
Input: [1,2,4,8,16]
Output: Truthy
Input: [7,16,76]
Output: Falsey
Input: [7,16,1000]
Output: Truthy
Input: [545, 1044, 266, 2240]
Output: Truthy
Input: [1282, 2068, 137, 584]
Output: Falsey
Input: [274728976, 546308480, 67272744, 135004166, 16790592, 33636865]
Output: Truthy
Input: [134285315, 33849872, 553780288, 544928, 4202764, 345243648]
Output: Falsey
источник
==
равенством могли бы спасти байт, если бы истину и фальшивость можно было перевернуть.Ответы:
Желе , 4 байта
Попробуйте онлайн!
Проверьте, равна ли сумма побитовой сумме (т.е.
a+b+c == a|b|c
).источник
Python
32,554342 байта-12 байт от мистера Xcoder
-1 байт от стержня
Попробуйте онлайн!
Объяснение: Проверяет, равна ли сумма чисел битовой или чисел.
источник
lambda l:sum(l)==eval("|".join(map(str,l)))
Python 2 , 37 байт
Попробуйте онлайн!
Еще один порт алгоритма pizzapants184 ...
источник
Чисто , 38 байт
Попробуйте онлайн!
Еще один порт.
источник
Japt, 6 байт
Еще один порт с решениями pizzapants184 и Leaky Nun.
Проверь это
источник
JavaScript (ES6),
373534 байтаСохранено 2 байта благодаря @ Mr.Xcoder
Сохранено 1 байт благодаря @ETHproductions
Сравнение суммы с побитовым ИЛИ (как сделали pizzapants184 и Leaky Nun ) на
134 байта короче, чем мой первоначальный подход:Контрольные примеры
Показать фрагмент кода
Чередующийся версия, 38 байт
Контрольные примеры
Показать фрагмент кода
источник
a=>(q=c=>eval(a.join(c)))`|`==q`+`;
Haskell , 38 байт
(==).sum<*>foldl1 xor
является анонимной функцией, возвращающейBool
. Используйте как((==).sum<*>foldl1 xor) [2,0,1]
.Попробуйте онлайн!
Практически тот же трюк от pizzapants184 и Leaky Nun, который используют все, за исключением того, что с именами операторов Haskell он сохраняет один байт для использования (побитовый)
xor
вместо(.|.)
(побитовый или).(==).sum<*>foldl1 xor
это бессмысленная версия\l->sum l==foldl1 xor l
.источник
Java 8, 53 байта
Порт ответа @LeakyNun 's Jelly .
Объяснение:
Попробуй это здесь.
источник
Pyth , 6 байт
Тестирование.
источник
Шелуха , 5 байт
Попробуйте онлайн!
источник
Perl 6 , 15 байт
Проверь это
Expanded:
источник
Красный , 78 байт
Как это устроено:
Ungolfed:
Попробуйте онлайн!
источник
Wolfram Language (Mathematica) , 15 байтов
Попробуйте онлайн!
источник
Пакетный, 73 байта
Выходы
1
для правды, ничего для фальши. Еще один очевидный порт для пиццы 184 / Алгоритм Leaky Nun.источник
J , 10 байт
Еще один порт с решениями для пиццерий184 и Leaky Nun.
Как это устроено?
+/.&.#:
- преобразовать числа в двоичные числа, применить их поразрядно или к степеням двух и преобразовать обратно из двоичного числа в десятичное+/
- уменьшить ввод путем сложения=
- равны ли выше?Попробуйте онлайн!
Простая альтернатива
J , 12 байт
Как это устроено?
+/@#:
- преобразовать каждое число в двоичное и найти сумму каждой степени 2>./
- найти максимум2>
- это меньше, чем 2? -> правдаПопробуйте онлайн!
источник
Треугольность , 31 байт
Попробуйте онлайн!
Альтернативный раствор, 31 байт
Попробуйте онлайн!
источник