実際には、12 11バイト
Leaky Nunの多くの提案に感謝します。ゴルフの提案を歓迎します。オンラインでお試しください!
;)R♀ⁿ♀%0@íu
元の12バイトのアプローチ。オンラインでお試しください!
1WX│1╖╜ⁿ%WX╜
別の12バイトのアプローチ。オンラインでお試しください!
w┬i)♀/♂K@♀ⁿπ
13バイトのアプローチ。オンラインでお試しください!
k╗2`╜iaⁿ%Y`╓N
アンゴルフ:
最初のアルゴリズム
Implicitly pushes y, then x.
; Duplicate x.
) Rotate duplicate x to bottom of the stack.
R Range [1, x] (inclusive).
♀ⁿ Map a**y over the range.
♀% Map a**y%x over the range.
0@í new_list.index(0)
u Increment and print implicitly at the end of the program.
元のアルゴリズム
Implicitly pushes x, then y.
1WX Pushes a truthy value to be immediately discarded
(in future loops, we discard a**y%x)
| Duplicates entire stack.
Stack: [y x y x]
1╖ Increment register 0.
╜ Push register 0. Call it a.
ⁿ Take a to the y-th power.
% Take a**y mod x.
W If a**y%x == 0, end loop.
X Discard the modulus.
╜ Push register 0 as output.
第三のアルゴリズム
Implicitly pushes y, then x.
w Pushes the full prime factorization of x.
┬ Transposes the factorization (separating primes from exponents)
i Flatten (into two separate lists of primes and exponents).
) Rotate primes to the bottom of the stack.
♀/ Map divide over the exponents.
♂K Map ceil() over all of the divided exponents.
@ Swap primes and modified exponents.
♀ⁿ Map each prime ** each exponent.
π Product of that list. Print implicitly at the end of the program.
4番目のアルゴリズム
Implicitly pushes x, then y.
k╗ Turns stack [x y] into a list [x, y] and saves to register 0.
2 Pushes 2.
` Starts function with a.
╜i Pushes register 0 and flattens. Stack: [x y a]
a Inverts the stack. Stack: [a y x]
ⁿ% Gets a**y%x.
Y Logical negate (if a**y is divisible by x, then 1, else 0)
` End function.
╓ Push first (2) values where f(x) is truthy, starting with f(0).
N As f(0) is always truthy, get the second value.
Print implicitly at the end of the program.