日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

【LeetCode】50. Pow(x, n) (3 solutions)

發(fā)布時(shí)間:2025/3/15 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【LeetCode】50. Pow(x, n) (3 solutions) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Pow(x, n)

Implement pow(x,?n).

?

按照定義做的O(n)肯定是TLE的。

利用這個(gè)信息:x2n = (xn)2

有個(gè)注意點(diǎn),當(dāng)n為負(fù)是,直接取反是不可行的。

由于int的表示范圍是[2-31, 231-1],當(dāng)n為INT_MIN時(shí),取反會(huì)溢出。

因此需要對(duì)n==INT_MIN單獨(dú)考慮。

另外,除以2可以用右移1位來(lái)實(shí)現(xiàn)。

?

解法一:遞歸

class Solution { public:double pow(double x, int n) {if(n < 0){if(n == INT_MIN) //-INT_MIN will cause overflowreturn pow(x, n+1)/x;else{x = 1/x;n = -n;}}return Helper(x, n);}double Helper(double x, int n){//n > 0if(n == 0)return 1;double partRes = Helper(x, n>>1);if(n%2 == 1)return partRes*partRes*x;elsereturn partRes*partRes;} };

?

解法二:非遞歸

對(duì)于n的二進(jìn)制表示,考慮每一位的0/1。

舉例n==5,二進(jìn)制表示為101

右數(shù)第一位為1,需要乘以x

右數(shù)第二位為0,不需要乘以x2

右數(shù)第三位為1,需要乘以x4

class Solution { public:double pow(double x, int n) {if(n == 0)return 1;int sign = 1; if(n == INT_MIN)return pow(x, n+1) / x;else if(n < 0){sign *= -1;n *= -1;}double ret = 1;double mul = x;while(n){if(n & 1)ret *= mul;n >>= 1;mul *= mul;}if(sign == 1)return ret;elsereturn 1 / ret;} };

?

解法三:just a joke

class Solution { public:double pow(double x, int n) {return std::pow(x,n);} };

轉(zhuǎn)載于:https://www.cnblogs.com/ganganloveu/p/4161167.html

總結(jié)

以上是生活随笔為你收集整理的【LeetCode】50. Pow(x, n) (3 solutions)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。