C++快速幂算法q_pow() - 详解

在C++编程中,我们常常需要解决类似于a^n之类的问题,

这时候,我们就需要面临一个严重(说实话,不是很严重)的问题:超时

此时,就可以用快速幂q_pow()算法来实现问题。

 首先,先了解一下什么是快速幂:

快速幂,即一种利用简单二分算法实现的递归程序,用于实现 a^n 或 a^n%m 等问题。

 下面是快速幂的模板:(没有很难,只是用了一个非常非常非常简单的位运算)

1.用if-else语句实现递归操作:

typedef long long LL;
LL q_pow(int a, int n) {                 //a为底数,n为指数
	if (n == 0)                          //指数为0,直接返回1
		return 1;
	int tmp = q_pow(a, n >> 1);          //二分思想,每次取半
	if (n % 2 == 0)                      //判断奇偶
		return tmp * tmp;                //如果为奇数,则直接相乘
	else 
		return a * tmp * tmp;            //如果为偶数,则相乘后再乘底数
}

2.用三目运算

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值