classSolution { public: intmySqrt(int x){ int left = 1; int right = x / 2; if(x < 2) { return x; } while(left <= right) { int mid = left + (right-left)/2; if(x/mid > mid) { left = mid + 1; } elseif(x/mid < mid) { right = mid - 1; } else { return mid; } } return (left+right)/2; } };
解决方案2(Python)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
classSolution(object): defmySqrt(self, x): """ :type x: int :rtype: int """ left = 1 right = x / 2 if x < 2: return x while left <= right: mid = left + (right-left)/2 if x/mid > mid: left = mid + 1 elif x/mid < mid: right = mid - 1 else: return mid return (left+right)/2