【每天学习一点算法 2026/04/11】Pow(x, n)

每天学习一点算法 2026/04/11

题目:Pow(x, n)

实现 pow(x , n) ,即计算 x 的整数 n 次幂函数(即,xn )。

最简单的办法就是循环 n 次乘 n 次 x,但是这样其实有全是重复的操作,我们需要优化一下。

我们知道如果 n 是偶数:
x n = x n / 2 ∗ x n / 2 x ^ n = x ^ {n/2} * x ^ {n/2} xn=xn/2∗xn/2

如果 n 是奇数:
x n = x n − 1 / 2 ∗ x n − 1 / 2 ∗ x x ^ n = x ^ {n - 1 / 2} * x ^ {n - 1 / 2} * x xn=xn−1/2∗xn−1/2∗x

我们可以利用这个规律递归求 x 的 n 次幂

typescript 复制代码
function myPow(x: number, n: number): number {
  // 递归快速求幂
  function helper (res: number, m: number) {
    if (m == 1) {
      // 1 次幂直接返回 res
      return res
    }
    if (m % 2 === 1) {
      // 奇数
      return helper(res * res, Math.floor(m / 2)) * res
    } else {
      // 偶数
      return helper(res * res, Math.floor(m / 2))
    }
  }
  if (n ==  0) return 1 // 0 直接返回 1
  if (n > 0) return helper(x, n) // 正数次幂
  if (n < 0) return 1 / helper(x, n * -1) // 负数次幂
};

以 19 为例其实过程大概就是这个样子:
x 19 = x 9 ∗ x 9 ∗ x x 9 = x 4 ∗ x 4 ∗ x x 4 = x 2 ∗ x 2 还有一步就不写了 x ^ {19} = x ^ 9 * x ^ 9 * x \\ x ^ {9} = x ^ 4 * x ^ 4 * x \\ x ^ {4} = x ^ 2 * x ^ 2 \\ 还有一步就不写了 x19=x9∗x9∗xx9=x4∗x4∗xx4=x2∗x2还有一步就不写了

效率很高

题目来源:力扣(LeetCode)

相关推荐
夏天想21 小时前
人类将从“执行者“变为“总导演”,学习Ai知识
人工智能·学习
晓梦林1 天前
Baji1靶场学习笔记
笔记·学习
希冀1231 天前
【CSS学习第十一篇】
前端·css·学习
黎阳之光1 天前
黎阳之光:以视频孪生重构智能监盘,为燃机打造新一代智慧电厂大脑
大数据·人工智能·算法·安全·数字孪生
绝知此事1 天前
【算法突围 02】树形结构与数据库索引:树形结构与数据库索引:从 BST 到 B+ 树的演化与 MySQL 优化
数据库·mysql·算法·面试·b+树
魔法阵维护师1 天前
从零开发游戏需要学习的c#模块,第十六章(安装 MonoGame 并创建第一个窗口)
学习·游戏·c#·monogame
xian_wwq1 天前
【学习笔记】大模型备案到底要交什么材料
笔记·学习
清木!1 天前
排序算法比较
数据结构·算法·排序算法
吴可可1231 天前
用Teigha修改并保存CAD文件
数据库·算法·c#
老鱼说AI1 天前
统计学习方法第一章讲解:统计与监督学习概率
人工智能·学习·学习方法