C++實(shí)現(xiàn)LeetCode( 69.求平方根)
[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.
這道題要求我們求平方根,我們能想到的方法就是算一個(gè)候選值的平方,然后和x比較大小,為了縮短查找時(shí)間,我們采用二分搜索法來找平方根,找最后一個(gè)不大于目標(biāo)值的數(shù),這里細(xì)心的童鞋可能會(huì)有疑問,在總結(jié)貼中第三類博主的 right 用的是開區(qū)間,那么這里為啥 right 初始化為x,而不是 x+1 呢?因?yàn)榭偨Y(jié)帖里的 left 和 right 都是數(shù)組下標(biāo),這里的 left 和 right 直接就是數(shù)字本身了,一個(gè)數(shù)字的平方根是不可能比起本身還大的,所以不用加1,還有就是這里若x是整型最大值,再加1就會(huì)溢出。最后就是返回值是 right-1,因?yàn)轭}目中說了要把小數(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ù)中好像講到過這個(gè)方法,是用逼近法求方程根的神器,在這里也可以借用一下,因?yàn)橐?x2 = n 的解,令 f(x)=x2-n,相當(dāng)于求解 f(x)=0 的解,可以求出遞推式如下:
xi+1=xi - (xi2 - 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);
}
};
也是牛頓迭代法,寫法更加簡(jiǎn)潔一些,注意為了防止越界,聲明為長(zhǎng)整型,參見代碼如下:
解法三:
class Solution {
public:
int mySqrt(int x) {
long res = x;
while (res * res > x) {
res = (res + x / res) / 2;
}
return res;
}
};
到此這篇關(guān)于C++實(shí)現(xiàn)LeetCode( 69.求平方根)的文章就介紹到這了,更多相關(guān)C++實(shí)現(xiàn)求平方根內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C++實(shí)現(xiàn)LeetCode(73.矩陣賦零)
- C++實(shí)現(xiàn)LeetCode(72.編輯距離)
- C++實(shí)現(xiàn)LeetCode(71.簡(jiǎn)化路徑)
- C++實(shí)現(xiàn)LeetCode(68.文本左右對(duì)齊)
- C++實(shí)現(xiàn)LeetCode(67.二進(jìn)制數(shù)相加)
- C++實(shí)現(xiàn)LeetCode(66.加一運(yùn)算)
- C++實(shí)現(xiàn)LeetCode(174.地牢游戲)
- C++實(shí)現(xiàn)LeetCode(81.在旋轉(zhuǎn)有序數(shù)組中搜索之二)
相關(guān)文章
C++實(shí)現(xiàn)LeetCode(114.將二叉樹展開成鏈表)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(114.將二叉樹展開成鏈表),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C/C++?Qt?選擇夾TabWidget組件實(shí)現(xiàn)導(dǎo)航欄切換
Tab切換在很多地方都可以使用的到,本文就使用TabWidget組件來實(shí)現(xiàn)一下,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
C++實(shí)現(xiàn)判斷一個(gè)字符串是否為UTF8或GBK格式的方法
這篇文章主要介紹了C++實(shí)現(xiàn)判斷一個(gè)字符串是否為UTF8或GBK格式的方法,涉及C++針對(duì)字符編碼的遍歷、判斷、編碼轉(zhuǎn)換等相關(guān)操作技巧,需要的朋友可以參考下2017-11-11
Qt數(shù)據(jù)庫(kù)應(yīng)用之實(shí)現(xiàn)文件編碼格式識(shí)別
在做數(shù)據(jù)導(dǎo)入導(dǎo)出的過程中,如果應(yīng)用場(chǎng)景多了,相信各位都會(huì)遇到一個(gè)問題就是文件編碼的問題。本文將用Qt實(shí)現(xiàn)文件編碼格式識(shí)別,感興趣的可以了解一下2022-06-06
詳解C++中二進(jìn)制求補(bǔ)運(yùn)算符與下標(biāo)運(yùn)算符的用法
這篇文章主要介紹了C++中二進(jìn)制求補(bǔ)運(yùn)算符與下標(biāo)運(yùn)算符的用法,是C++入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2016-01-01
與ASCII碼相關(guān)的C語言字符串操作函數(shù)
這篇文章主要介紹了與ASCII碼相關(guān)的C語言字符串操作函數(shù),分別是將字符轉(zhuǎn)換為ASCII碼的toascii()函數(shù)和根據(jù)ASCII碼進(jìn)行字符串比較的strcoll()函數(shù),需要的朋友可以參考下2015-08-08
C++設(shè)計(jì)模式之享元模式(Flyweight)
這篇文章主要為大家詳細(xì)介紹了C++設(shè)計(jì)模式之享元模式Flyweight,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04
C語言實(shí)現(xiàn)電影院選座管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)電影院選座管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12

