C语言 快速幂

快速幂


快速求a的b次幂。
<math.h>中的pow函数的时间复杂度为O(n),快速幂可以解决此问题。

求a^b如果将b进行处理,让其有某种规律进行运算。

在计算机中,按照二进的方式进行运算,所以将b=>1011,ab=>a(23)*a(21)*a(2^0),所以将b二进为1的的乘上。

#include<stdio.h>
int main(){
    int a,b,arr=1;
    scanf("%d%d",&a,&b);
    while(b!=0){
        if((b&1)!=0)
            arr*=a;
        a*=a;
        b>>=1;
    }
    printf("%d",arr);
    return 0;
}

b&1:因为要寻找二进制为一的,&1就是“与”1,如果最后一位是1则a*b(开始2^0所以直接乘后边对b作用进行幂运算)


a*=a:对b进行幂运算,如不考虑二进位是否为一,则是a2,a4,a8…=>a21,a22,a2^3…。


b>>=1:将b二进向右移一位

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值