博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
快速幂
阅读量:6921 次
发布时间:2019-06-27

本文共 486 字,大约阅读时间需要 1 分钟。

快速幂

  如何快速计算nm?我们采用从特殊到一般的数学思想:

  假设n=2,m=10

  直接算的结果是2*2*2*2*...*2  计算了10次

  快速幂的思想是将m二进制化

  210=4*16*16 计算了3次

  同理可得,nm用快速幂来计算的过程是使底数不断倍增,指数倍减,达到时间上的优化:O(N)->O(logN)

  模板:

1 //读者可以根据自己的需要,更改返回值的类型 2 long long qpow(long long d){ 3     long long a=10,ans=1;//我们假设是求10^d 4     while(d>0){ 5         if(d&1)ans=(ans*a)%n;//当指数倍减至奇数时,和答案相乘 6         a=(a*a)%n;//底数倍增 7         d>>=1;//指数倍减 8     } 9     return ans;//返回答案10 }11 //根据二进制的拆分,时间复杂度是对数级别的

 

 

 

转载于:https://www.cnblogs.com/maopengsen/p/4181382.html

你可能感兴趣的文章
我的友情链接
查看>>
拆笔记本
查看>>
STP的作用
查看>>
浅谈正则表达式
查看>>
win7下安装linux操作系统,实现双系统
查看>>
js比较两个"日期时间"的大小
查看>>
sshd_config 中文手册
查看>>
前端常用工具记录
查看>>
Spring学习总结(4)——Spring AOP教程
查看>>
scanf函数详解(上)
查看>>
SCVMM 2012 R2创建逻辑网络和VM网络
查看>>
SCVMM 2012 R2之添加hyper-v主机
查看>>
在pfSense中配置Wi-Fi + Lan桥接接入点
查看>>
【译】如何通过简单的3步恢复Windows7同时删除Ubuntu
查看>>
std::call_once
查看>>
鼠标提示文字
查看>>
Oracle数据库升级路线图
查看>>
一个操作系统的实现-笔记
查看>>
JSF标签与参数使用说明
查看>>
[转载] 用心工作,做无可替代的你——致我的助理
查看>>