博客
关于我
快速指数算法
阅读量:414 次
发布时间:2019-03-06

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

出问题了,程序好像错了,这两天考试,考完试改

问题简介

在RSA中,加、解密过程都是要求某个整数的整数次幂后再取模。大多时候,这两个整数都会比较大,这时候直接按含义来进行计算时得到的中间结果会超出计算机所允许的整数取值范围(例如计算\(66^{77}\),这还是比较小的);另一方面,我们也要考虑计算的效率,如\(66^{77}\)直接按照定义计算的话需要做76次乘法,开销是相当大的。针对这两个问题,我们就需要有一个好的算法来高效且准确地计算大整数的幂运算。

初步思路

针对第一个问题,即数值过大问题,可以考虑利用模运算的性质:

\[(a*b)(mod n) = [(a (mod n))*(b (mod n))](mod n)\]

就能有效减小中间值。

针对第二个问题,可以利用指数的性质,对每个部分的结果重复做平方运算,最低可以将运算次数减为\(log_2n\),如计算\(x^{16}\)时,可以按照如下方式进行:

\[x^2,x^4,x^8,x^{16}\]

只需要计算4次,比按照定义计算减少了3/4。

快速指数算法

快速指数算法整合了上面两种思想,算法描述如下:

通常,在我们计算\(a^mmodn\)时,先将m表示为二进制形式\(b_k,b_{k-1},...,b_0\),即

\[m = \sum\limits_{b_i=1}2^i\]

因此,

\[a^m = a^{\sum\limits_{b_i=1}2^i} = \prod\limits_{b_i=1}a^{2^i}\]

\[a^mmodn = [\prod\limits_{b_i=1}a^{2^i}]modn = \prod\limits_{b_i=1}[a^{2^i}modn]\]

代码简略实现:

d = 1for i in range(k+1):    d = d*d%n    if b[i] == '1':        d = d*a%n

突然想起来,今天林老师课上说我们讲义上错误真的很多,但我相信以你们的能力都能纠正过来,呜呜呜,我哭辣,一下午就记住这一句话

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

你可能感兴趣的文章
NIO三大组件基础知识
查看>>
NIO与零拷贝和AIO
查看>>
NIO同步网络编程
查看>>
NIO基于UDP协议的网络编程
查看>>
NIO笔记---上
查看>>
Vue3.0中的响应式原理(第九课)
查看>>
NIO蔚来 面试——IP地址你了解多少?
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
NISP国家信息安全水平考试,收藏这一篇就够了
查看>>
NIS服务器的配置过程
查看>>
NIS认证管理域中的用户
查看>>
Nitrux 3.8 发布!性能全面提升,带来非凡体验
查看>>
NiuShop开源商城系统 SQL注入漏洞复现
查看>>
NI笔试——大数加法
查看>>
NLog 自定义字段 写入 oracle
查看>>
NLog类库使用探索——详解配置
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 时事和见解【2023】
查看>>
NLP 模型中的偏差和公平性检测
查看>>
Vue3.0 性能提升主要是通过哪几方面体现的?
查看>>