博客
关于我
快速幂算法介绍
阅读量: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/

你可能感兴趣的文章
node.js+react写的一个登录注册 demo测试
查看>>
Node.js中环境变量process.env详解
查看>>
Node.js之async_hooks
查看>>
Node.js初体验
查看>>
Node.js升级工具n
查看>>
Node.js卸载超详细步骤(附图文讲解)
查看>>
Node.js卸载超详细步骤(附图文讲解)
查看>>
Node.js基于Express框架搭建一个简单的注册登录Web功能
查看>>
node.js学习之npm 入门 —8.《怎样创建,发布,升级你的npm,node模块》
查看>>
Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
查看>>
Node.js安装及环境配置之Windows篇
查看>>
Node.js安装和入门 - 2行代码让你能够启动一个Server
查看>>
node.js安装方法
查看>>
Node.js官网无法正常访问时安装NodeJS的方法
查看>>
node.js模块、包
查看>>
node.js的express框架用法(一)
查看>>
Node.js的交互式解释器(REPL)
查看>>
Node.js的循环与异步问题
查看>>
Node.js高级编程:用Javascript构建可伸缩应用(1)1.1 介绍和安装-安装Node
查看>>
nodejs + socket.io 同时使用http 和 https
查看>>