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.

題目解讀

  • 看代碼即可

代碼

  • 思路一
#include<stdio.h>

int mySqrt(int x)
{
    int i,flag=0;

    if(x==1){
        return 1;
    }
    else{
       for(i=0;i<=x/2;i++){  
          if(i*i - x <= 0){
            flag=i;
          }
          else{
             flag = i-1;
             break;
          }
       }
    }
    return flag;
}
int main()
{
   printf("%d\n", mySqrt(2147395600));
}
  • 思路二 二分查找遞歸實(shí)現(xiàn)
class Solution {
public:
    int mySqrt(int x) {
        if(x == 0 || x == 1){
            return x;
        }
        
        return BinarySearch(0, x/2, x);
    }
    
    int BinarySearch(int left, int right, int target){
        int med = (left + right) / 2;
        if((double)med*med - (double)target < 0){
            if((double)(med+1)*(med+1) - (double)target > 0){
                return med;
            }
            return BinarySearch(med+1, right, target);
        }
        else if((double)med*med - (double)target > 0){
            if((double)(med-1)*(med-1) - (double)target < 0){
                return med-1;
            }
            return BinarySearch(left, med-1, target);
        }
        else{
            return med;
        }
    }
};
  • 思路三 二分查找循環(huán)實(shí)現(xiàn)
class Solution {
public:
    int mySqrt(int x) {
        if(x == 0 || x == 1){
            return x;
        }
        
        int result = 0;
        int left = 0;
        int right = x/2;
        int med = 0;
        
        while(left <= right){
            med = (left + right) / 2;    
            if((double)med*med - (double)x < 0){
                if((double)(med+1)*(med+1) - (double)x > 0){
                    result = med;
                    break;
                }
                left = med + 1;
            }
            else if((double)med*med - (double)x > 0){
                if((double)(med-1)*(med-1) - (double)x < 0){
                    result = med-1;
                    break;
                }
                right = med-1;
            }
            else{
                result = med;
                break;
            }
        }
        return result;
    }
};

總結(jié)展望

  • 思路一到思路三,效率逐步提高
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末据途,一起剝皮案震驚了整個(gè)濱河市赡磅,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖怠晴,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異彼宠,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)弟塞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門凭峡,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人决记,你說我怎么就攤上這事摧冀。” “怎么了系宫?”我有些...
    開封第一講書人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵索昂,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我扩借,道長(zhǎng)椒惨,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任潮罪,我火速辦了婚禮康谆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘嫉到。我一直安慰自己沃暗,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開白布何恶。 她就那樣靜靜地躺著孽锥,像睡著了一般。 火紅的嫁衣襯著肌膚如雪细层。 梳的紋絲不亂的頭發(fā)上惜辑,一...
    開封第一講書人閱讀 51,573評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音疫赎,去河邊找鬼韵丑。 笑死,一個(gè)胖子當(dāng)著我的面吹牛虚缎,可吹牛的內(nèi)容都是我干的撵彻。 我是一名探鬼主播,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼实牡,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼陌僵!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起创坞,我...
    開封第一講書人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤碗短,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后题涨,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體偎谁,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡总滩,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了巡雨。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片闰渔。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖铐望,靈堂內(nèi)的尸體忽然破棺而出冈涧,到底是詐尸還是另有隱情,我是刑警寧澤正蛙,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布督弓,位于F島的核電站,受9級(jí)特大地震影響乒验,放射性物質(zhì)發(fā)生泄漏愚隧。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一锻全、第九天 我趴在偏房一處隱蔽的房頂上張望奸攻。 院中可真熱鬧,春花似錦虱痕、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至响委,卻和暖如春新思,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背赘风。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工夹囚, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人邀窃。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓荸哟,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親瞬捕。 傳聞我的和親對(duì)象是個(gè)殘疾皇子鞍历,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

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

  • rljs by sennchi Timeline of History Part One The Cognitiv...
    sennchi閱讀 7,332評(píng)論 0 10
  • pyspark.sql模塊 模塊上下文 Spark SQL和DataFrames的重要類: pyspark.sql...
    mpro閱讀 9,456評(píng)論 0 13
  • 沒有任何征兆,突如其來的霧霾一夜之間侵襲了整個(gè)城市肪虎。樓宇劣砍、樹木籠罩在灰蒙蒙的霧氣中,影影綽綽扇救,街上的車流閃...
    風(fēng)中吟唱閱讀 723評(píng)論 0 2
  • 曾經(jīng) 你是否讓痛苦深深陷入 可你是否知道 我們永遠(yuǎn)不會(huì)受困不前 因?yàn)槲覀兛偰軌蚋淖冏约旱乃枷?曾經(jīng) 你是否感到深深...
    一塵九九閱讀 247評(píng)論 0 2
  • 前言 很久前看了《Objective-C高級(jí)編程 iOS與OS X多線程和內(nèi)存管理》這本書刑枝,但當(dāng)時(shí)看起來晦澀難懂香嗓。...
    Dwyane_Coding閱讀 2,573評(píng)論 0 22