二分法,注意考虑溢出
class Solution { public: /** * * @param x int整型 * @return int整型 */ int mysqrt(int x) { // write code here // 需要考虑溢出 if (x <= 0) return 0; int left = 1, right = x; while (left < right) { long middle = (left + right) / 2; if (middle * middle <= x && (middle + 1) * (middle + 1) > x) return middle; if (middle * middle > x) right = middle; else left = middle; } return left; } };