快速幂运算模板
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是针对幂运算求模。
以上是关于快速幂运算模板的主要内容,如果未能解决你的问题,请参考以下文章