强大的快速幂!!!
模板题目
int quickpower(int a,int b){
int ans=1;
while(b&1){
if(b&1) ans*=a;
a*=a;
b>>=1;
}
return ans;
}
快速幂很容易溢出,所以一般用long long,但long long 的数据范围只有差不多10的18次方,所以每进行一次乘法一般就会取mod…
解释代码
int quickPower(int a, int b)//是求a的b次方
{
int ans = 1, base = a;//ans为答案,base为a^(2^n)
while(b > 0)//b是一个变化的二进制数,如果还没有用完
{
if(b & 1)//&是位运算,b&1表示b在二进制下最后一位是不是1,如果是:
{ans *= base;}//把ans乘上对应的a^(2^n)
base *= base;//base自乘,由a^(2^n)变成a^(2^(n+1))
b >>= 1;//位运算,b右移一位,如101变成10(把最右边的1移掉了),10010变成1001。现在b在二进制下最后一位是刚刚的倒数第二位。结合上面b & 1食用更佳
}
return ans;
}