Sqrt(x)

Problem Summary

(Write in your own words, not copied from LeetCode. This forces comprehension.)

Key Observations

(Patterns, constraints, or hints in the problem statement.)

Main Concepts Used

(Mark the CS concepts or algorithms used.)

Time & Space Complexity

Code

class Solution:
    def mySqrt(self, x: int) -> int:
        l, r = 1, x
        
        while l <= r:
            m = (l+r) // 2
            if m * m == x:
                return m
            elif m * m > x:
                r = m - 1
            else:
                l = m + 1
        # return l if l * l < x else l - 1
        return r

Common Mistakes / Things I Got Stuck On