题解 | #数值的整数次方#

数值的整数次方

http://www.nowcoder.com/practice/1a834e5e3e1a4b7ba251417554e07c00

经典的快速幂算法

#include <iostream>
using namespace std;
class Solution {
public:
    double myPow(double x, int n) {
        if (n < 0) {
            if (n == INT32_MIN) { // 这里有个边界值需要注意
                n /= 2;
                x *= x;
            }
            x = 1 / x;
            n = -n;
        }
        double result = 1.0;
        while (n) { // 经典的快速幂算法
            if (n & 1) result *= x;
            n >>= 1;
            x *= x;
        }
        return result;
    }
};
int main() {
    Solution s;
    for (int i = -3; i < 10; ++i) {
        cout << s.myPow(2.0, i) << endl;
    }
    return 0;
}
题解 文章被收录于专栏

本专栏收录的题解不求类似“一行代码”之类的奇技淫巧,只求开阔思路的适合大众提升编程思维的朴实无华的算法。

全部评论

相关推荐

认真搞学习:28小登的建议,投算法岗不要写什么物理竞赛,互联网+,多写点项目,用什么算法做了什么。还有本科算法是不可能的开发你这个也没有项目啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务