-
快速幂取模算法详解
1.大数模幂运算的缺陷:
快速幂取模算法的引入是从大数的小数取模的朴素算法的局限性所提出的,在朴素的方法中我们计算一个数比如5^1003%31是非常消耗我们的计算资源的,在整个计算过程中最麻烦的就是我们的5^1003这个过程缺点1:在我们在之后计算指数的过程中,计算的数字不都拿得增大,非常的占用我们的计算资源(主要是时间,还有空间)缺点2:我们计算的中间过程数字大的恐怖,我们现有的计算机是没有办法记录这么长的数据的,所以说我们必须要想一个更加高效的方法来解决这个问题2.快速幂的引入:
我们首先从优化的过程开始一步一步优化我们的模幂算法1.朴素模幂运算过程:
- #define ans=1
- for(int i=1;i<=b;i++)
- {
- ans*=a;
- }
在这里我们如果要做优化的话,我肥就是每个过程中都加一次模运算,但是我们首先要记住模运算是非常的消耗内存资源的,在计算的次数非常的大的时候,我们是没有办法忍受这种时间耗费的2.快速幂引入:
在讲解快速幂取模算法之前,我们先将几个必备的知识1.对于取模运算:- (a*b)%c=(a%c)*(b%c)%c
之后我们来看看快速幂的核心本质我通过离散课上的学习,将快速幂的本质差不多理解了一下,感觉还是很深刻的在这里&
Powmod快速幂取模
最新推荐文章于 2024-06-17 15:33:37 发布
本文详细介绍了快速幂取模算法,对比了朴素模幂运算的缺陷,并通过实例展示了快速幂算法的高效性。文章还提供了C++和Python的代码实现,包括OJ例题,用于验证算法的正确性和速度优势。
摘要由CSDN通过智能技术生成