当前位置: 首页 > news >正文

华为云怎么建网站湖北联诺建设网站

华为云怎么建网站,湖北联诺建设网站,本地购物平台有哪些,装饰工程公司经营范围快速幂算法 快速幂算法可用分治法实现 不难看出,对任意实数a和非负整数n,有: a n { 1 , n 0 , a ≠ 0 0 , a 0 ( a n 2 ) 2 , n > 0 , n 为偶数 ( a n 2 ) 2 ∗ a , n > 0 , n 为奇数 a^n \begin{cases} 1, & n 0, a\neq 0…

快速幂算法

快速幂算法可用分治法实现

不难看出,对任意实数a和非负整数n,有:
a n = { 1 , n = 0 , a ≠ 0 0 , a = 0 ( a n 2 ) 2 , n > 0 , n 为偶数 ( a n 2 ) 2 ∗ a , n > 0 , n 为奇数 a^n = \begin{cases} 1, & n = 0, a\neq 0 \\ 0, & a = 0 \\ \left( a^\frac{n}{2} \right)^2, & n > 0, n \text{为偶数} \\ \left( a^\frac{n}{2} \right)^2*a, & n > 0, n \text{为奇数} \end{cases} an= 1,0,(a2n)2,(a2n)2a,n=0,a=0a=0n>0,n为偶数n>0,n为奇数
这里n/2是C语言中的整除计算,所以n为奇数时需要额外乘一个a
n=0可作为递归边界

递归实现

  • a如果等于0则返回0

  • n=0时作为递归边界返回1

  • n不等于0时,递归求 a n 2 a^\frac{n}{2} a2n的值,再根据n的奇偶性返回相应值

代码
double exp2(int a, int n){if (a == 0)return 0;if (n <= 0)return 1;else{int x = exp2(a, n/2);if (n % 2)return x * x *a;return x * x;}
}

时间复杂度为O(logn)

非递归实现

非递归实现的方法在于将指数n分解乘二进制,将对应二进制位为1的乘起来,就得到最终的结果

例:计算 3 93 3^{93} 393

93 = ( 1011101 ) 2 = 64 + 16 + 8 + 4 + 1 93=(1011101)_2=64+16+8+4+1 93=(1011101)2=64+16+8+4+1

3 93 = 3 64 ∗ 3 16 ∗ 3 8 ∗ 3 4 ∗ 3 3^{93}=3^{64}*3^{16}*3^{8}*3^{4}*3 393=36431638343

代码
  • 变量s存储当前计算结果,并最终作为返回值

  • 变量b存储当前数位的乘方值

  • 遍历n的每一个二进制位

    • n & 1判断指数当前的最后一位是否为1
    • 每次循环将指数n右移一位(除以2),并将b累乘一次,计算当前的乘方
double exp2(int a, int n) {double b, s = 1.0;b = a;while (n > 0) {if (n & 1) {s *= b;}n /= 2;b *= b;}return s;
}

因为n有logn+1个二进制位,只需要次计算就能得到 a n a^n an,时间复杂度为O(n)

测试
double exp2(int a, int n) {double b, s = 1.0;b = a;while (n > 0) {if (n & 1) {s *= b;}n /= 2;b *= b;}return s;
}
int main()
{cout << exp2(3, 93);return 0;
}

结果

在这里插入图片描述

在这里插入图片描述

结果正确

由于递归算法涉及到对栈的操作,一般建议使用非递归算法

http://www.yayakq.cn/news/292873/

相关文章:

  • 自己的网站怎么做进销存广告公司名字大全集
  • 网站如何备份数据dll网站服务
  • swift 网站开发海口的网站建设公司
  • 如何给自己网站做网站优化cad制图培训
  • 怎么查找网站死链手机网站设计只找亿企邦
  • 定边网站建设wordpress502
  • 汕头企业网站建设流程广州市学校安全教育平台官网
  • 中山网站建设公司哪个好第一ppt模板官网
  • 保定中小企业网站制作如何做微商城网站
  • 做网站的是些什么公司物流网站开题报告
  • 深圳做装修网站费用树莓派做网站服务器性能怎么样
  • 楚天网站建设合同佛山市城市建设档案馆网站
  • 制作网站的程序语言中文企业网站模板下载
  • 苏州营销型网站建设推广网站中链接怎么做的
  • Editplus做网站洛阳网站建设优化案例
  • 哪里公司建设网站好济南市做网站公司
  • 温州做微网站seo外链自动群发工具
  • 网站流量来源查询上海公司注册查询官网
  • 网站建设费与无形资产wordpress制作会员功能
  • 可以做编程题的网站贵州住房城乡建设厅官方网站
  • 正规网站设计制作公司在哪个网站可以做行测题
  • 公司网站 自己是空间服务商 cmsseo实战指导
  • 个人网站备案备注信息WordPress多网络
  • 注册建公司网站页面设计心得体会
  • 网站开发的基本技术网站图标怎么做的
  • 洛阳制作网站公司哪家好dw网页制作超链接
  • 新塘网站建设合肥瑶海区事业单位
  • 企业网站一般用什么域名免费seo培训
  • python做网站模板酒厂网站源码
  • 论坛网站模板下载管理咨询公司最专业的公司