栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

python 幂运算(python中幂的表示方法)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

python 幂运算(python中幂的表示方法)

前言

使用快速幂的原因,针对高次幂计算,如果使用循环遍历的方法,时间开销比较大eg:8^10000000000 而使用快速幂的方法可以在O(log(次幂))的复杂度内完成。

示例
import time
start=time.time()
p=1000000007
def quick_count(a,b):
    sum=1
    while b!=0:
        if b&1:
            sum=sum*a%p
        b>>=1
        a*=a#注意是x自身,容易写成x2, x2对应到阶乘下+1而非x2
    return sum
print(quick_count(2,10000000))
print(time.time()-start)


说明eg:2^8 8=>1000

2^8=>((2^4)^2))
(((2^2)^2)^2)
迭代过程:
2 (2)^2 (2^2)^2 (2^2^2)^2

对比一般遍历程序:

import time
start=time.time()
p=1000000007
def quick_count(a,b):
    sum=1
    for i in range(0,b):
        sum=sum*a%p
    return sum
print(quick_count(2,10000000))
print(time.time()-start)

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/772883.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号