题解 | #数值的整数次方#
数值的整数次方
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; }
题解 文章被收录于专栏
本专栏收录的题解不求类似“一行代码”之类的奇技淫巧,只求开阔思路的适合大众提升编程思维的朴实无华的算法。