博客
关于我
快速幂算法介绍
阅读量:243 次
发布时间:2019-03-01

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

计算一个数的幂次,其实是不用计算N次的

 

 

//递归快速幂int qpow(int a, int n){    if (n == 0)        return 1;    else if (n % 2 == 1)        return qpow(a, n - 1) * a;    else    {        int temp = qpow(a, n / 2);        return temp * temp;    }}

 

快速幂取模

//递归快速幂(对大素数取模)#define MOD 1000000007typedef long long ll;ll qpow(ll a, ll n){    if (n == 0)        return 1;    else if (n % 2 == 1)        return qpow(a, n - 1) * a % MOD;    else    {        ll temp = qpow(a, n / 2) % MOD;        return temp * temp % MOD;    }}

 

//非递归快速幂int qpow(int a, int n){    int ans = 1;    while(n){        if(n&1)        //如果n的当前末位为1            ans *= a;  //ans乘上当前的a        a *= a;        //a自乘        n >>= 1;       //n往右移一位    }    return ans;}

 

转载地址:http://xsmv.baihongyu.com/

你可能感兴趣的文章
Mysql在离线安装时启动失败:mysql服务无法启动,服务没有报告任何错误
查看>>
Mysql在离线安装时提示:error: Found option without preceding group in config file
查看>>
MySQL基于SSL的主从复制
查看>>
Mysql基本操作
查看>>
mysql基本操作
查看>>
mysql基础
查看>>
mysql基础---mysql查询机制
查看>>
MySQL基础5
查看>>
MySQL基础day07_mysql集群实例-MySQL 5.6
查看>>
Mysql基础命令 —— 数据库、数据表操作
查看>>
Mysql基础命令 —— 系统操作命令
查看>>
MySQL基础学习总结
查看>>
mysql基础教程三 —常见函数
查看>>
mysql基础教程二
查看>>
mysql基础教程四 --连接查询
查看>>
MySQL基础知识:创建MySQL数据库和表
查看>>
MySQL基础系列—SQL分类之一
查看>>
MySQL处理千万级数据分页查询的优化方案
查看>>
mysql备份
查看>>
mysql备份与恢复
查看>>