快速幂讲解

原文地址:http://www.cnblogs.com/CXCXCXC/p/4641812.html


快速幂这个东西比较好理解,但实现起来到不老好办,记了几次老是忘,今天把它系统的总结一下防止忘记。

  首先,快速幂的目的就是做到快速求幂,假设我们要求a^b,按照朴素算法就是把a连乘b次,这样一来时间复杂度是O(b)也即是O(n)级别,快速幂能做到O(logn),快了好多好多。它的原理如下:

  假设我们要求a^b,那么其实b是可以拆成二进制的,该二进制数第i位的权为2^(i-1),例如当b==11时

             a^11=a^(2^0+2^1+2^3)
   11的二进制是1011,11 = 2³×1 + 2²×0 + 2¹×1 + 2º×1,因此,我们将a¹¹转化为算 a^(2^0)*a^(2^1)*a^(2^3)
,看出来快的多了吧原来算11次,现在算三次,但是这三项貌似不好求的样子....不急,下面会有详细解释。
 
  由于是二进制,很自然地想到用位运算这个强大的工具: &  和 >>  
 
  &运算通常用于二进制取位操作,例如一个数 & 1 的结果就是取二进制的最末位。还可以判断奇偶x&1==0为偶,x&1==1为奇。
 
  >>运算比较单纯,二进制去掉最后一位,不多说了,先放代码再解释。
 
  
 1 int poww(int a,int b){
 2     int ans=1,base=a;
 3     while(b!=0){
 4         if(b&1!=0)
 5           ans*=base;
 6         base*=base;
 7         b>>=1;
 8   }
 9     return ans;
10 }

  代码很短,死记也可行,但最好还是理解一下吧,其实也很好理解,以b==11为例,b=>1011,二进制从右向左算,但乘出来的顺序是 a^(2^0)*a^(2^1)*a^(2^3),是从左向右的。我们不断的让base*=base目的即是累乘,以便随时对ans做出贡献。

       其中要理解base*=base这一步,看:::base*base==base^2,下一步再乘,就是base^2*base^2==base^4,然后同理  base^4*base4=base^8,,,,,see?是不是做到了base-->base^2-->base^4-->base^8-->base^16-->base^32.......指数正是 2^i 啊,再看上  面的例子,a¹¹= a^(2^0)*a^(2^1)*a^(2^3),这三项是不是完美解决了,,嗯,快速幂就是这样。

  顺便啰嗦一句,由于指数函数是爆炸增长的函数,所以很有可能会爆掉int的范围,根据题意决定是用 long long啊还是unsigned int啊还是mod某个数啊自己看着办。

  还有,矩阵快速幂的求法唯一的区别就是*换成矩阵中的乘法,写个函数代换嘛,思想一毛一样。。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
快速模幂运算是一种常用的数学计算方法,用于求解大数的幂运算取模问题。它的原理基于数学中的取模运算和幂运算,而快速幂运算则是求解幂运算的一种高效的方法。 首先,我们需要了解以下两个数学概念: 1. 取模运算:取模运算就是将一个数除以另一个数后所得到的余数。例如,5除以2的余数为1,即5 mod 2 = 1。 2. 幂运算:幂运算就是将一个数乘以自己若干次的结果。例如,2的3次方等于8,即2^3 = 8。 接下来,我们来讲解快速模幂的原理和过程: 假设要求解 a^b mod c 的值,其中 a、b、c 均为正整数,其中 b 可以非常大,达到几百万甚至更大,此时计算 a^b mod c 的常规方法是直接计算 a 的 b 次方,然后再对 c 取模。这种方法的时间复杂度是 O(b)。如果 b 很大,计算时间就会很长,效率很低。 快速模幂算法的核心思想是利用幂运算的性质和取模运算的性质将 b 分解为若干个二进制位,然后对每个二进制位进行计算。具体过程如下: 1. 将 b 转换为二进制数,例如,b=13,二进制表示为:1101。 2. 从右往左扫描二进制数,对于每一位,若该位为 1,则将对应的幂运算结果乘到最终结果中,否则直接忽略。 3. 在计算过程中,用已经计算出来的结果不断平方,然后对 c 取模,这样可以避免重复计算,提高计算效率。 举个例子,我们要计算 2^13 mod 7 的值,可以使用快速模幂算法进行计算: 1. 将 13 转换为二进制数,即 13 = 1101。 2. 从右往左扫描二进制数,对于每一位,若该位为 1,则将相应的幂运算结果乘到最终结果中,否则直接忽略。计算过程如下: - 2^1 mod 7 = 2 - 2^2 mod 7 = 4 - 2^4 mod 7 = 2 - 2^8 mod 7 = 4 - 2^13 mod 7 = 2 * 4 * 2 * 4 * 2 mod 7 = 8 mod 7 = 1 因此,2^13 mod 7 的值为 1。 快速幂算法是求解幂运算的一种高效的方法,其核心思想是利用幂运算的性质将指数进行二进制分解,然后利用分治思想进行计算。具体过程如下: 1. 将指数 b 转化成二进制数,例如,b=13,二进制表示为:1101。 2. 从右往左扫描二进制数,对于每一位,若该位为 1,则将底数 a 的对应次方乘到最终结果中,否则直接忽略。 3. 在计算过程中,用已经计算出来的结果不断平方,这样可以避免重复计算,提高计算效率。 举个例子,我们要计算 2^13 的值,可以使用快速幂算法进行计算: 1. 将 13 转换为二进制数,即 13 = 1101。 2. 从右往左扫描二进制数,对于每一位,若该位为 1,则将相应的幂运算结果乘到最终结果中,否则直接忽略。计算过程如下: - 2^1 = 2 - 2^2 = 4 - 2^4 = 16 - 2^8 = 256 - 2^13 = 2 * 4 * 16 * 256 * 2 = 32768 因此,2^13 的值为 32768。 快速幂算法和快速模幂算法都是常用的数学计算方法,在实际应用中经常被使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值