快速求幂(位操作)
1
2
3
4
5
6
7
8
9
10
11
12
|
int
pow3(
int
a,
int
b )
{
int
r = 1, base = a;
while
( b != 0 )
{
if
( b & 1 )
r *= base;
base *= base;
b >>= 1;
}
return
r;
}
|
快速求幂(更高效率的位运算法)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
int
pow4(
int
x,
int
n)
{
int
result;
if
(n == 0)
return
1;
else
{
while
((n & 1) == 0)
{
n >>= 1;
x *= x;
}
}
result = x;
n >>= 1;
while
(n != 0)
{
x *= x;
if
((n & 1) != 0)
result *= x;
n >>= 1;
}
return
result;
}
|
http://blog.csdn.net/prstaxy/article/details/8740838
二分求幂,最初是在剑指offer上看到,书中给出了递归的代码,后来在王道机试指南上再次看到,那上面给出了非递归的代码。
二分求幂的原理如图:
剑指offer上的递归代码如下:
- double powerWithUnsignedExponent(double base,unsigned int exponent)
- {
- if(exponent==0)
- return 1;
- if(exponent==1)
- return base;
- double result=powerWithUnsignedExponent(base,exponent>>1);//exponent>>1即exponent/2
- result*=result;
- if(exponent & 0x1==1)//a & 0x1相当于a%2
- result*=base;
- return result;
- }
王道书上的非递归代码如下:
- int power(int a,int b)
- {
- int ans=1;
- while(b!=0)
- {
- if(b%2==1)
- ans*=a;
- b/=2;
- a*=a;
- }
- return ans;
- }