整数幂
算法1:对实数x的n次幂设计一个有效的算法。一种直接的方法是对x用迭代方法自乘n次,这种方法十分低效,因为它需要O(n)乘法。一个高效的方法可以用如下方法推出,令m=n/2,假设已经知道如何计算x^m。那么有两种情况:如果n是偶数,那么x^n = (x^m)^2;否则x^n = x(x^m)^2。
算法2:令n的二进制表示为dn-1.....d1,d0。从y=1开始,由n的高位至地位扫描,如果二进制数字为0,就对y平方;如果为1就对y平方并乘x。这就产生了递归算法EXPREC。
时间复杂度:很明显该算法的时间复杂度为O(logn) --考虑n的二进制长度
思路:由于从n的高位至低位扫描,而低位是很容易取的,因此我们想到栈,由低位至高位将二进制数依次压栈,那么栈顶即是高位,因而递归的形式是显然的。
代码:
#include<iostream> using namespace std; long long _pow(long long a, long long i) { if(i==0) return 1; long long temp = _pow(a,i>>1); temp = temp * temp; if(i&1) temp = temp * a; return temp; } int main() { long long a = 4; long long i = 5; cout<<_pow(4,5)<<endl; return 1; }
时间: 2024-10-30 14:36:03