LeetCode [69. Sqrt(x)] 難度[easy]

題目

Implement int sqrt(int x).

Compute and return the square root of x.


解題思路

題目讓我們實現(xiàn) sqrt 函數(shù)沾谓,具體實現(xiàn)有以下兩種方法:

1. 二分查找
第一個方法是二分查找践盼,范圍為 [1, Integer.MAX_VALUE]章贞,看哪個數(shù)的平方會等于 x绞佩,這里需要注意的是 不能直接判斷 midmid == x,因為 midmid 數(shù)值可能很大,從而導致溢出「炫纾可以轉(zhuǎn)化為判斷 mid == x/mid。該算法的時間復雜度為 O(log(Integer.MAX_VALUE))夭织。

2. Newton's method
牛頓大法好厌蔽,沒想到求一個數(shù)的平方根也可以用到牛頓方法。下面是我在網(wǎng)上找到的有關(guān) Newton's method 的介紹:

牛頓迭代法(Newton's method)又稱為牛頓-拉夫遜方法(Newton-Raphson method)摔癣,它是牛頓在17世紀提出的一種在實數(shù)域和復數(shù)域上近似求解方程的方法奴饮。多數(shù)方程不存在求根公式,因此求精確根非常困難择浊,甚至不可能戴卜,從而尋找方程的近似根就顯得特別重要。方法使用函數(shù)f(x)的泰勒級數(shù)的前面幾項來尋找方程f(x) = 0的根琢岩。牛頓迭代法是求方程根的重要方法之一投剥,其最大優(yōu)點是在方程f(x) = 0的單根附近具有平方收斂,而且該法還可以用來求方程的重根担孔、復根江锨。另外該方法廣泛用于計算機編程中。

設(shè)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次近似值,上式稱為牛頓迭代公式徘键。

根據(jù)牛頓迭代的原理练对,將 f(x) = x^2 代進去即可得到以下的迭代公式:X(n+1)=[X(n)+p/X(n)]/2,具體代碼見參考代碼啊鸭。


參考代碼

1. 二分查找

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

2. Newton's method

class Solution {
public:
    int mySqrt(int x) {
        long r = x;
        while (r*r > x)
            r = (r + x/r) / 2;
        return r;
    }
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末锹淌,一起剝皮案震驚了整個濱河市匿值,隨后出現(xiàn)的幾起案子赠制,更是在濱河造成了極大的恐慌,老刑警劉巖挟憔,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件钟些,死亡現(xiàn)場離奇詭異,居然都是意外死亡绊谭,警方通過查閱死者的電腦和手機政恍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來达传,“玉大人篙耗,你說我怎么就攤上這事∠芨希” “怎么了宗弯?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長搂妻。 經(jīng)常有香客問我蒙保,道長,這世上最難降的妖魔是什么欲主? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任邓厕,我火速辦了婚禮,結(jié)果婚禮上扁瓢,老公的妹妹穿的比我還像新娘详恼。我一直安慰自己,他們只是感情好引几,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布单雾。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪硅堆。 梳的紋絲不亂的頭發(fā)上屿储,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天,我揣著相機與錄音渐逃,去河邊找鬼够掠。 笑死,一個胖子當著我的面吹牛茄菊,可吹牛的內(nèi)容都是我干的疯潭。 我是一名探鬼主播,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼面殖,長吁一口氣:“原來是場噩夢啊……” “哼竖哩!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起脊僚,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤相叁,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后辽幌,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體增淹,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年乌企,在試婚紗的時候發(fā)現(xiàn)自己被綠了虑润。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡加酵,死狀恐怖拳喻,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情猪腕,我是刑警寧澤冗澈,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站码撰,受9級特大地震影響渗柿,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜脖岛,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一朵栖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧柴梆,春花似錦陨溅、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽雹有。三九已至,卻和暖如春臼寄,著一層夾襖步出監(jiān)牢的瞬間霸奕,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工吉拳, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留质帅,地道東北人。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓留攒,卻偏偏與公主長得像煤惩,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子炼邀,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345

推薦閱讀更多精彩內(nèi)容

  • C語言的學習要從基礎(chǔ)開始魄揉,這里是100個經(jīng)典的算法-1C語言的學習要從基礎(chǔ)開始,這里是100個經(jīng)典的 算法 題目:...
    Poison_19ce閱讀 1,124評論 0 0
  • 生活中拭宁,我們可能遇到這樣的情況洛退,朋友小明向你借10000元,保證5個月連本帶息還給你红淡。假設(shè)你手上有如下兩套方案: ...
    Jiao123閱讀 9,458評論 1 11
  • 轉(zhuǎn)自Poll 的筆記 閱讀目錄 梯度下降法(Gradient Descent) 牛頓法和擬牛頓法(Newton's...
    JSong1122閱讀 1,360評論 0 3
  • 文︱萌 我們都知道習慣的神奇力量不狮,那么怎么才能夠養(yǎng)成一個好習慣呢降铸?我覺得養(yǎng)成習慣的過程就像談戀愛一樣在旱,要經(jīng)歷初識、...
    萌愛佑佑閱讀 156評論 1 5
  • 等待,讓我在如花的年齡變得像草一樣干枯谅畅。那個人登渣,隔著一條街,我等他毡泻!隔著厚厚的時差時胜茧,我還等他。 在大...
    孜然味summer閱讀 399評論 3 2