LeetCode 69. x 的平方根

题目:
给定整数x,求\(\sqrt{x}\)

解法:
本题有两种常用解法,第一种自然是二分法,不再赘述,要注意的是可能会溢出,需要用long long。第二种是牛顿迭代法,利用导数逼近零点的方法。对于函数\(y=f(x)\),我们任意取初始点\(x_0\),然后不断迭代令\(x_{i+1}=x_i-\frac{f(x_i)}{f'(x_i)}\),图示如下:
image-20220420111959027

代码:

//二分法
class Solution {
public:
    int mySqrt(int a) {
        int l = 0, r = a, ans = -1;
        while (l <= r) {
            int mid = l + (r - l) / 2;
            if ((long long)mid * mid <= a) {
                ans = mid;
                l = mid + 1;
            }
            else {
                r = mid - 1;
            }
        }
        return ans;
    }
};
//牛顿迭代法
class Solution {
public:
    int mySqrt(int a) { //要求a^0.5,即求y=x^2-a的零点,导数为y'=2x
        double x = 0, x_ = 1;
        while (floor(x_) != floor(x)) {
            x = x_;
            x_ = x - 0.5 * (x * x - a) / x;
        }
        return floor(x_);
    }
};
posted @ 2022-04-20 11:22  Unparalleled_Calvin  阅读(19)  评论(0编辑  收藏  举报