博客
关于我
AcWing90 64位整数乘法
阅读量:794 次
发布时间:2019-03-25

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

快速幂的优化方法及代码分析

快速幂是一种常见的优化算法,尤其在处理大数幂次时非常有效。它通过二分法将底数进行拆分,从而减少计算量。以下是该算法的核心原理及实现方法:

快速幂的思路是基于二进制分解,通过将指数分解为二进制位来逐步完成幂次运算。在实际实现中,可以选择用加法或者乘法来完成快速幂的计算。以下是两种方法的简要说明:

快速幂的加法实现

将底数分解为二进制形式,每一位代表一个乘 法项。例如,底数为3,指数为7时,7的二进制为111。因此,3^7可以表示为:

3^7 = 3 * 3^2 * 3^4
这与加法实现的方式类似于:
ans = ans + 3,3每次被右移一位并乘以2。即:
ans = ans + a,a每次乘2后向右移一位。

快速幂的乘法实现

在乘法实现中,通常采用平方优化,通过不断将底数平方并结合即时乘法进行计算。例如,3^7可以表示为:

3^7 = 3 * 3^2 * 3^4
这可以通过递归的方法快速计算,每次将指数减半并平方底数。

代码分析

以下是基于加法的快速幂实现代码:

#include 
using namespace std;typedef unsigned long long ull;ull binaryMul(ull a, ull b, ull p) { ull ans = 0; while (b > 0) { if (b & 1) { ans = (ans + a) % p; } a = 2 * a % p; b >>= 1; } return ans;}int main() { ull a, b, p; cin >> a >> b >> p; cout << binaryMul(a, b, p) << endl;}

代码解析

  • variable命名binaryMul函数用于实现快速幂运算,接口参数分别为底数a、指数b、模数p
  • 循环逻辑:循环执行直至指数b为0。
    • 检查最低位:如果b的最低位为1,则加入当前结果。
    • 底数更新:底数右移并乘以2(模运算)。
    • 指数右移:逐步将b右移一位,减少指数规模。
  • 退出条件:当指数b为0时,返回结果ans
  • 这种方法通过指数二分和模运算优化,能够高效处理大数幂次问题。

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

    你可能感兴趣的文章
    NIO基于UDP协议的网络编程
    查看>>
    NIO笔记---上
    查看>>
    NIO蔚来 面试——IP地址你了解多少?
    查看>>
    NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
    查看>>
    NISP国家信息安全水平考试,收藏这一篇就够了
    查看>>
    NIS服务器的配置过程
    查看>>
    Nitrux 3.8 发布!性能全面提升,带来非凡体验
    查看>>
    NiuShop开源商城系统 SQL注入漏洞复现
    查看>>
    NI笔试——大数加法
    查看>>
    NLog 自定义字段 写入 oracle
    查看>>
    NLog类库使用探索——详解配置
    查看>>
    NLP 基于kashgari和BERT实现中文命名实体识别(NER)
    查看>>
    NLP 模型中的偏差和公平性检测
    查看>>
    Vue3.0 性能提升主要是通过哪几方面体现的?
    查看>>
    NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
    查看>>
    NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
    查看>>
    NLP三大特征抽取器:CNN、RNN与Transformer全面解析
    查看>>
    NLP学习笔记:使用 Python 进行NLTK
    查看>>
    NLP度量指标BELU真的完美么?
    查看>>
    NLP的不同研究领域和最新发展的概述
    查看>>