LeetCode Pow(x, n) (快速幂)

题意

Implement pow(x, n).
求X的N次方。

解法

用正常的办法来做是会超时的,因为可能有21亿次方的情况,所以需要优化一下。这里用到了快速幂算法,简单来说就是将指数分解成二进制的形式,比如X的7次方,就可以表示成X^1 * X^2 * X^4,这里将7分解成了1+2+4的形式,这样做之后,乘法就只需要进行三次,所以要做的就是一边把指数分解成二进制的形式,一边记录不同指数下值。

class Solution
{
public:
	double myPow(double x, int n)
	{
		if (abs(x - 0) < 10e-10)
			return	0;

		long	n_l = n;
		if (n_l < 0)
		{
			x = 1 / x;
			n_l = -n_l;
		}

		double	ans = 1;
		double	box = x;
		while (n_l)
		{
			if (n_l & 1)
				ans *= box;
			box *= box;
			n_l >>= 1;
		}

		return	ans;
	}
};
posted @   Decouple  阅读(537)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
点击右上角即可分享
微信分享提示