快速求幂

只会写递归的,应该学学非递归的。 也是O(lgn)。

比如要计算$a^b$,把b写成二进制,假设$b=11_{(10)}=1011_{(2)}=2^3+2^1+2^0$;所以$a^{11}=a^{2^3+2^1+2^0}=a^{2^3}*a^{2^3}*a^{2^0}$。

这样我也就可以把每一位的乘积项先给算出来,也就是每一次循环算出$a^{2^n}=$a^{2^{n-1}}*a^{2^{n-1}}$。如果b的第n位二进制如果为1,结果就要乘以这个项,如果为0,则不需要;

1 int power(int a, int b) {
2     int ans = 1;
3     for (; b; b >>= 1) {
4         if (b & 0x01) ans *= a;
5         a *= a;
6     }
7     return ans;
8 }

 

转载于:https://www.cnblogs.com/linyx/p/4020227.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值