亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++怎么求平方根

發布時間:2022-03-28 13:52:31 來源:億速云 閱讀:535 作者:iii 欄目:大數據

這篇“C++怎么求平方根”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“C++怎么求平方根”文章吧。

Sqrt(x) 求平方根

Example 1:

Input: 4
Output: 2

Example 2:

Input: 8
Output: 2
Explanation: The square root of 8 is 2.82842..., and since
the decimal part is truncated, 2 is returned.

這道題要求我們求平方根,我們能想到的方法就是算一個候選值的平方,然后和x比較大小,為了縮短查找時間,我們采用二分搜索法來找平方根,找最后一個不大于目標值的數,這里細心的童鞋可能會有疑問,在總結貼中第三類博主的 right 用的是開區間,那么這里為啥 right 初始化為x,而不是 x+1 呢?因為總結帖里的 left 和 right 都是數組下標,這里的 left 和 right 直接就是數字本身了,一個數字的平方根是不可能比起本身還大的,所以不用加1,還有就是這里若x是整型最大值,再加1就會溢出。最后就是返回值是 right-1,因為題目中說了要把小數部分減去,只有減1才能得到正確的值,代碼如下:

解法一:

class Solution {
public:
    int mySqrt(int x) {
        if (x <= 1) return x;
        int left = 0, right = x;
        while (left < right) {
            int mid = left + (right - left) / 2;
            if (x / mid >= mid) left = mid + 1;
            else right = mid;
        }
        return right - 1;
    }
};

這道題還有另一種解法,是利用牛頓迭代法,記得高數中好像講到過這個方法,是用逼近法求方程根的神器,在這里也可以借用一下,因為要求 x2 = n 的解,令 f(x)=x2-n,相當于求解 f(x)=0 的解,可以求出遞推式如下:

xi+1=xi - (xi- n) / (2xi) = xi - xi / 2 + n / (2xi) = xi / 2 + n / 2xi = (xi + n/xi) / 2

解法二:

class Solution {
public:
    int mySqrt(int x) {
        if (x == 0) return 0;
        double res = 1, pre = 0;
        while (abs(res - pre) > 1e-6) {
            pre = res;
            res = (res + x / res) / 2;
        }
        return int(res);
    }
};

也是牛頓迭代法,寫法更加簡潔一些,注意為了防止越界,聲明為長整型,參見代碼如下:

解法三:

class Solution {
public:
    int mySqrt(int x) {
        long res = x;
        while (res * res > x) {
            res = (res + x / res) / 2;
        }
        return res;
    }
};

以上就是關于“C++怎么求平方根”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

阳城县| 林口县| 通辽市| 日照市| 万荣县| 鹤峰县| 时尚| 朝阳市| 长汀县| 金塔县| 张北县| 凉城县| 维西| 广州市| 东海县| 安塞县| 宜阳县| 高清| 莱西市| 岫岩| 长丰县| 兴文县| 宝坻区| 神农架林区| 融水| 芜湖县| 新野县| 天柱县| 遂昌县| 南丰县| 闽清县| 祁门县| 闻喜县| 扎鲁特旗| 山东省| 淮滨县| 临邑县| 旺苍县| 武宁县| 文安县| 基隆市|