二分求幂,快速求幂

快速求幂(位操作)

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上的递归代码如下:

[cpp]  view plain copy
  1. double powerWithUnsignedExponent(double base,unsigned int exponent)  
  2. {  
  3.     if(exponent==0)  
  4.         return 1;  
  5.     if(exponent==1)  
  6.         return base;  
  7.     double result=powerWithUnsignedExponent(base,exponent>>1);//exponent>>1即exponent/2   
  8.     result*=result;  
  9.     if(exponent & 0x1==1)//a & 0x1相当于a%2   
  10.         result*=base;  
  11.     return result;  
  12. }  

王道书上的非递归代码如下:

[cpp]  view plain copy
  1. int power(int a,int b)  
  2. {  
  3.     int ans=1;  
  4.     while(b!=0)  
  5.     {  
  6.         if(b%2==1)  
  7.             ans*=a;  
  8.         b/=2;  
  9.         a*=a;  
  10.     }  
  11.     return ans;  
  12. }  




评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值