快速幂运算模板

Posted shadowcharle

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了快速幂运算模板相关的知识,希望对你有一定的参考价值。

ll pow(ll a,ll b)    //long long型
{
  ll ans=1;
  while(b!=0)
  {
    if(b%2==1)  //if(b&1)
      ans=ans*a%mod;//如果是奇数次幂,因为b下面是除以2操作,会少一次乘,这里要提前乘上去。 
    a=a*a%mod;//快速幂,每一次是上一次的平方倍 
    b=b/2;
  }
  return ans;
}

 

分析:

  将指数b看成二进制,b%2==1即判断当前b二进制最低位是否为1,是则将当前底数a与累积ans相乘,否则跳过。在每次循环中都将底数a扩大一倍,将指数b缩小一半。其中mod是针对幂运算求模。

以上是关于快速幂运算模板的主要内容,如果未能解决你的问题,请参考以下文章

快速幂基本模板

快速幂运算模板

LuoguP1226 模板快速幂||取余运算

[每日一题2020.06.15]P1226 模板快速幂取余运算

从矩阵快速幂的泛型模板设计——教你如何优雅的面向对象

快速幂模板