幂次方的四种快速取法(不使用pow函数)
Pow(x, n)
- 方法一:暴力法
- 方法二:递归快速幂算法
- 方法三:迭代快速幂算法
- 方法四:位运算法
方法一:暴力法
思路
只需模拟将 x
相乘 n
次的过程。
如果
但我们需要注意极端情况,尤其是负整数和正整数的不同范围限制。
算法
我们可以用一个简单的循环来计算结果。
class Solution {
public:
double myPow(double x, int n) {
long long N = n;
if (N < 0) {
x = 1 / x;
N = -N;
}
double ans = 1;
for (long long i = 0; i < N; i++)
ans = ans * x;
return ans;
}
};
复杂度分析
- 时间复杂度:
。我们将x
相乘n
次。 - 空间复杂度:
。我们需要一个变量来存储x
的最终结果。
方法二:递归快速幂算法
class Solution {
public:
double fastPow(double x, long long n) {
if (n == 0) {
return 1.0;
}
double half = fastPow(x, n / 2);
if (n % 2 == 0) {
return half * half;
} else {
return half * half * x;
}
}
double myPow(double x, int n) {
long long N = n;
if (N < 0) {
x = 1 / x;
N = -N;
}
return fastPow(x, N);
}
};
复杂度分析
- 时间复杂度:O(log(n))O(log(n))。每次我们应用公式$ (x ^ n) ^ 2 = x ^ {2 * n}
n$ 就减少一半。 因此,我们最多需要 次计算来得到结果。 - 空间复杂度:
。每次计算,我们都需要存储 的结果。 我们需要计算 次,因此空间复杂度为 。
方法三:迭代快速幂算法
递归或迭代的快速幂实际上是实现同一目标的不同方式。
class Solution {
public:
double myPow(double x, int n) {
long long N = n;
if (N < 0) {
x = 1 / x;
N = -N;
}
double ans = 1;
double current_product = x;
for (long long i = N; i ; i /= 2) {
if ((i % 2) == 1) {
ans = ans * current_product;
}
current_product = current_product * current_product;
}
return ans;
}
};
复杂度分析
- 时间复杂度:
。对于n
的每个二进制位,我们最多只能乘一次。所以总的时间复杂度为 。 - 空间复杂度:
。我们只需要两个变量来存储x
的当前乘积和最终结果。
位运算实现pow(x,n)
根据暴力法的思路来看特别简单,但通过位运算呢?
我举个例子吧,例如 n = 13,则 n 的二进制表示为 1101, 那么 m 的 13 次方可以拆解为:
我们可以通过 & 1和 >>1 来逐位读取 1101,为1时将该位代表的乘数累乘到最终结果。直接看代码吧,反而容易理解:
int pow(int n){
int sum = 1;
int tmp = m;
while(n != 0){
if(n & 1 == 1){
sum *= tmp;
}
tmp *= tmp;
n = n >> 1;
}
return sum;
}
时间复杂度近为
分类:
算法----------
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· 分享4款.NET开源、免费、实用的商城系统
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 全程不用写代码,我用AI程序员写了一个飞机大战