Skip to content
LC-2543 Hard LeetCode

2543. Check if Point Is Reachable

Read the full problem statement on LeetCode.
Difficulty: hard Acceptance: 43% Topics: Math, Number Theory
View full problem on LeetCode

Reading material

Reference solution (spoiler · python)
# Time:  O(log(min(a, b)))
# Space: O(1)

# number theory
class Solution(object):
    def isReachable(self, targetX, targetY):
        """
        :type targetX: int
        :type targetY: int
        :rtype: bool
        """
        def gcd(a, b):
            while b:
                a, b = b, a%b
            return a
    
        g = gcd(targetX, targetY)
        return g == (g&~(g-1))  # co-prime other than factor 2

Solution from kamyu104/LeetCode-Solutions · MIT