欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實現(xiàn)LeetCode( 69.求平方根)

 更新時間:2021年07月17日 09:38:30   作者:Grandyang  
這篇文章主要介紹了C++實現(xiàn)LeetCode( 69.求平方根),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

[LeetCode] 69. Sqrt(x) 求平方根

Implement int sqrt(int x).

Compute and return the square root of x, where x is guaranteed to be a non-negative integer.

Since the return type is an integer, the decimal digits are truncated and only the integer part of the result is returned.

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比較大小,為了縮短查找時間,我們采用二分搜索法來找平方根,找最后一個不大于目標(biāo)值的數(shù),這里細(xì)心的童鞋可能會有疑問,在總結(jié)貼中第三類博主的 right 用的是開區(qū)間,那么這里為啥 right 初始化為x,而不是 x+1 呢?因為總結(jié)帖里的 left 和 right 都是數(shù)組下標(biāo),這里的 left 和 right 直接就是數(shù)字本身了,一個數(shù)字的平方根是不可能比起本身還大的,所以不用加1,還有就是這里若x是整型最大值,再加1就會溢出。最后就是返回值是 right-1,因為題目中說了要把小數(shù)部分減去,只有減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;
    }
};

這道題還有另一種解法,是利用牛頓迭代法,記得高數(shù)中好像講到過這個方法,是用逼近法求方程根的神器,在這里也可以借用一下,因為要求 x2 = n 的解,令 f(x)=x2-n,相當(dāng)于求解 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;
    }
};

到此這篇關(guān)于C++實現(xiàn)LeetCode( 69.求平方根)的文章就介紹到這了,更多相關(guān)C++實現(xiàn)求平方根內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • OpenCV使用鄰居訪問掃描圖像的操作方法

    OpenCV使用鄰居訪問掃描圖像的操作方法

    在圖像處理中,有時需要根據(jù)某個像素的相鄰像素的值計算該像素位置的值,當(dāng)這個鄰域包括上一行和下一行的像素時,就需要同時掃描圖像的多行像素,本節(jié)中我們將介紹如何通過鄰居訪問掃描圖像,感興趣的朋友一起看看吧
    2023-01-01
  • C++基于EasyX框架實現(xiàn)飛機(jī)大戰(zhàn)小游戲

    C++基于EasyX框架實現(xiàn)飛機(jī)大戰(zhàn)小游戲

    EasyX是針對C/C++的圖形庫,可以幫助使用C/C++語言的程序員快速上手圖形和游戲編程。本文將利用EasyX框架實現(xiàn)飛機(jī)大戰(zhàn)小游戲,需要的可以參考一下
    2023-01-01
  • C++無法打開源文件bits/stdc++.h的問題

    C++無法打開源文件bits/stdc++.h的問題

    這篇文章主要介紹了C++無法打開源文件bits/stdc++.h的問題以及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • C++實現(xiàn)消消樂游戲

    C++實現(xiàn)消消樂游戲

    這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)消消樂游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C語言 數(shù)據(jù)類型詳細(xì)介紹

    C語言 數(shù)據(jù)類型詳細(xì)介紹

    本文主要講解C語言 數(shù)據(jù)類型,這里整理了詳細(xì)的數(shù)據(jù)類型的資料,希望能幫助剛剛開始學(xué)習(xí)C語言的同學(xué)
    2016-08-08
  • C++二維數(shù)組螺旋加密信息

    C++二維數(shù)組螺旋加密信息

    大家好,本篇文章主要講的是C++二維數(shù)組螺旋加密信息,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • Linux下semop等待信號時出現(xiàn)Interrupted System Call錯誤(EINTR)解決方法

    Linux下semop等待信號時出現(xiàn)Interrupted System Call錯誤(EINTR)解決方法

    本篇文章是對在Linux下semop等待信號時出現(xiàn)Interrupted System Call錯誤(EINTR)的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言如何建立動態(tài)鏈表問題

    C語言如何建立動態(tài)鏈表問題

    這篇文章主要介紹了C語言如何建立動態(tài)鏈表問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 基于C++ Lambda表達(dá)式的程序優(yōu)化

    基于C++ Lambda表達(dá)式的程序優(yōu)化

    這篇文章主要介紹了基于C++ Lambda表達(dá)式的程序優(yōu)化的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02
  • Qt實現(xiàn)進(jìn)程間通信

    Qt實現(xiàn)進(jìn)程間通信

    這篇文章主要為大家詳細(xì)介紹了Qt實現(xiàn)進(jìn)程間通信,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08

最新評論