91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

java中怎么求一個正整數的平方根

發布時間:2021-07-30 16:55:18 來源:億速云 閱讀:450 作者:Leah 欄目:大數據

這篇文章給大家介紹java中怎么求一個正整數的平方根,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

一、二分法

二分法的思想很簡單,就是從0到N不斷的去縮小范圍來找一個一個滿足精度的最佳值。我們舉一個函數的例子:

java中怎么求一個正整數的平方根

這就是二分法的思想,求平方根也是,我們從0到value取出中間值,然后不斷地比較,假設value=10,查找區間為(0,10),這時候取(0,10)的中間值mid=5,mid*mid再和value比較之后,確定下一次查找的區間變為(0,5),依次類推。一直到滿足我們需要的精度即可。下面我們使用java代碼實現一下:

    static double MySqrt(int value, double t){
        if (value < 0 || t<0)
            return 0;
        double left = 0;
        double right = value;
        double mid = (right + left) / 2;
        double offset = 2*t ;
        while (offset>t){
            double temp = mid*mid;
            if (temp > value){
                right = (left + right) / 2;
                offset = temp - value;
            }
            if (temp <= value){
                left = (left + right) / 2;
                offset = value - temp;
            }
            mid = (left + right) / 2;
        }
        return mid;
    }
 

在這里value就是我們要求的數字,t表示的是精度。這個方法在這,大家可以測試一遍。不過在這里有一個小小的問題需要我們去注意:

如果我們對整數9取平方根,結果不是3,這里有精度損失,損失的原因之一是和計算機有關的,因為計算機的底層其實只有0和1,所以會無限的接近,而不能精確表示。

以上就是二分法求解的思想,這個思想很簡單,不過實現的方法卻是有一點點麻煩。在這里我們開始介紹第二種方法,那就是牛頓的微積分思想

 

二、牛頓迭代法

牛頓的微積分的思想就是無限接近,在這里提一句,如果你是數學大佬就不要追究思想到底是啥了。對于求平方根來說,使用切線來無限逼近的方式有時候能起到意想不到的效果。

設r是f(x) = 0的根,選取x0作為r初始近似值,過點(x0,f(x0))做曲線y = f(x)的切線L,

L的方程為y = f(x0)+f'(x0)(x-x0),求出L與x軸交點的橫坐標 x1 = x0-f(x0)/f'(x0),稱x1為r的一次近似值。

過點(x1,f(x1))做曲線y = f(x)的切線,并求該切線與x軸交點的橫坐標 x2 = x1-f(x1)/f'(x1),稱x2為r的二次近似值。

重復以上過程,得r的近似值序列,其中x(n+1)=x(n)-f(x(n))/f'(x(n)),稱為r的n+1次近似值,上式稱為牛頓迭代公式。

我們使用一張圖來演示一下:

java中怎么求一個正整數的平方根

這種方式也很好理解。所以我們直接來看實現:

static double SqrtIterator(int value,double t){
    double temp = value;
    while (fabs(temp*temp-value)>t){
        temp=(temp+value/temp) / 2.0;
    }
    return temp;
}
//取絕對值
private static double fabs(double a) {
    return (a < 0) ? -a : a;
}


關于java中怎么求一個正整數的平方根就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

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

AI

泰顺县| 高州市| 西峡县| 莱阳市| 阜平县| 景宁| 永仁县| 海口市| 双鸭山市| 赤水市| 唐海县| 台江县| 调兵山市| 揭阳市| 香港| 桦川县| 五指山市| 郯城县| 康定县| 西畴县| 新河县| 高雄县| 凤城市| 定兴县| 镇原县| 陵水| 新和县| 九寨沟县| 绥阳县| 安远县| 平和县| 云浮市| 临猗县| 老河口市| 新营市| 广西| 东宁县| 九龙县| 昔阳县| 桂阳县| 察隅县|