如何快速算出一个数的n次方?

简介: 先计算存储下来再求值,不失为一种好方法;但亦可以在计算 的同时判断 分解为 的幂(即转为 进制)后是否含 ,边计算边乘。形式化地,对于 位,其代表的幂 为 ()。这样,我们由低位向高位计算,每次将底数平方即可。下面两份伪代码,分别对应这种方法的如上两种实现。

本文主要讲解平方求幂(快速幂)相关,凡涉及大整数,都会进行对定值取模等处理,所以存储越界导致的错误、位数过多导致的单次运算缓慢的问题,不在考虑范围之内。


在许多地方常被用到,如Hash 相关、费马小定理、进制转换等。

一般来说,我们要求a的n次方 ,只需要将  a乘 n 次即可,时间复杂度为2YGYEK2LG1LWJ%(E0DZCR)A.png

但有时, n极大,这种方法需要的时间开销是不可接受的。

比如,求 C~S`1K0K[M8UQO2M@SG6~ER.png

如果我们直接计算多个这样的式子,至少在目前主流计算机中,所用时间以分钟计。

我们考虑如何优化对 a的n次方 的计算。



JD(T}09[%1S[D)19T5SM`DA.png



 640.jpg

[6}XR47FSCO@9SE6)ISTETE.png

这样我们就可以写出一份递归的伪代码:

function power(a, n):
 if n = 0 then return 1
 t := power(a, (n - n mod 2) / 2)
 if n mod 2 = 1
 then: return t^2 * a
 else: return t^2

每次将数据规模缩小为原来的一半,这种方法的时空复杂度是 [DTO72EKU_JVDXOR7$B_3~7.png

LXSYH_7~3J7P2BSS({(%28L.png



OJ)})DZBN4G@~LIJEYG)$HV.pngOJ)})DZBN4G@~LIJEYG)$HV.pngLXSYH_7~3J7P2BSS({(%28L.pngLXSYH_7~3J7P2BSS({(%28L.png

function power(a, n):
 pow[0...log n], pow[0] := 1
 for i: 1 to inf
  if (2^i > n) break
  else pow[i] = pow[i - 1]^2
 res := 1
 for i: 1 to inf
  if (2^i > n) break
  else:
   if (n bitand 2^i) res = res * pow[i]
 return res
# n bitand 2^i 可理解为 n 在二进制表示下含 2^i 位
function power(a, n):
 res := 1, p := a
 while n > 0:
  if (n bitand 1) then res = res * a
  p = p^2, n = n >> 1
 return res
# bitand 表示按二进制位与,>> 表示按二进制位右移(可理解为除以 2 下取整)。


J%JU%DX0O3I~H%INTVJ`B7R.png

 

HC{~`795K9%(}J2R$4IX6[U.png

function times(a, b, m):
 if b = 0 then return 0
 t := times(a, (b - b mod 2) / 2, m)
 if b mod 2 = 1
 then: return ((t + t) mod m + a mod m) mod m
 else: return (t + t) mod m

同样地,也可以对  进行二进制拆分。

function power(a, b, m):
 res := 0
 while b > 0:
  if (b bitand 1) then res = (res + a) mod m
  a = (a + a) mod m, b = b >> 1
 return res
# bitand 表示按二进制位与,>> 表示按二进制位右移(可理解为除以 2 下取整)。

这样,我们用 FMK~RRCAE`CFK{Y%RQ(}VP3.png 的时间复杂度算出了大数乘积取模的值。俗称龟速乘


事实上,平方求幂的思想,在任何具有结合律的、参与运算的数据相同的运算中,都可以使用。

如矩阵乘法等。

好了,快速求幂的方法就讲到这里,如果对你有哦帮助,欢迎点赞哦~~


相关文章
|
6月前
|
Python
如果一个n位正整数等于其各位数字的n次方之和
如果一个n位正整数等于其各位数字的n次方之和
|
3天前
|
C语言
计算一个数的 n 次方
【10月更文挑战第23天】计算一个数的 n 次方。
9 3
|
2月前
|
机器学习/深度学习 网络协议 Windows
几个数相加
几个数相加。
41 4
|
6月前
26.一个正整数如果恰好等于它的因子之和,这个数称为“完数”,如6=1+2+3,求1000以内所有的完数.
26.一个正整数如果恰好等于它的因子之和,这个数称为“完数”,如6=1+2+3,求1000以内所有的完数.
58 0
一个数如果恰好等于它的因子之和,这个数就称为“完数“。例如6=1+2+3.编程找出1000以内的所有完数
一个数如果恰好等于它的因子之和,这个数就称为“完数“。例如6=1+2+3.编程找出1000以内的所有完数
702 0
一个数如果恰好等于它的因子之和,这个数就称为“完数“。例如6=1+2+3.编程找出1000以内的所有完数
|
机器学习/深度学习 人工智能 算法
能被整除的数
能被整除的数
能被整除的数
打印0~100000之间的水仙花数, 水仙花数指一个n位数,其各位数的n次方之和正好等于该数本身
打印0~100000之间的水仙花数, 水仙花数指一个n位数,其各位数的n次方之和正好等于该数本身
104 0
076.计算高次方数的尾数
076.计算高次方数的尾数
124 0