信安数学(验证定理6.3.2~6.3.3)

定理6.3.2
如果n是对于基b的强伪素数,则n是对于基b得到欧拉伪素数

n=int(input("给定一奇合数n:"))
b=int(input("给定一个整数b:"))
def solution(a,b):#若b>a,则交换两个数的值if(b>a):t=aa=bb=tr = b #初始化rwhile(r!=0):r = a%b #r为a/b的余数a = bb = rreturn a  while(solution(n,b)!=1):n=int(input("重新给定一奇合数n"))b=int(input("重新给定一个整数b"))flag=False
s=1
t=(n-1)/pow(2,s)
if pow(b,t)%n==1:print('{0}是对于基{1}的强伪素数'.format(n,b))flag=True
else:while(t%2==0 or t%1!=0 ):#t必须是奇数还必须是整数t=(n-1)/pow(2,s)s+=1if pow(b,t)%n==1:print('{0}是对于基{1}的强伪素数'.format(n,b))flag=True##判断欧拉伪素数
if flag==True:q=(n-1)/2f=((n**2)-1)/8if pow(b,q)%n==1 and pow(-1,f)==1:print('{0}是对于基{1}的欧拉伪素数'.format(n,b))

在这里插入图片描述
定理6.3.2
设一个奇合数,则n是对于基b的强伪素数的可能性至多为25%

n=int(input("给定一奇合数n:"))
def solution(a,b):#若b>a,则交换两个数的值if(b>a):t=aa=bb=tr = b #初始化rwhile(r!=0):r = a%b #r为a/b的余数a = bb = rreturn a  ##我们需要找的是b
b=1
num=0
while(1<=b and b<=(n-1)):if solution(n,b)==1:##在这找到t的值s=1t=(n-1)/pow(2,s)if pow(b,t)%n==1:num+=1while(t%2==0 or t%1!=0 ):#t必须是奇数还必须是整数t=(n-1)/pow(2,s)s+=1if pow(b,t)%n==1:num+=1b+=1propertion=(num/(n-1))*100
if propertion<=25:print('可能性为{:.2f}%,且少于%25'.format(propertion))

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/498893.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

聊一聊Python量化交易

在金融领域&#xff0c;量化交易已经成为一种越来越受欢迎的交易方式。它通过使用数学模型来分析市场&#xff0c;自动化执行交易决策&#xff0c;以此来获取超额回报。近年来&#xff0c;Python因其简洁易学、功能强大而成为量化交易领域的首选编程语言。本文将详细介绍Python…

为什么猫咪挑食不吃猫粮?适口性好、普口性价的主食冻干推荐

现代养猫人士往往把自家的小猫看作是生活中的小宝贝&#xff0c;十分宠爱。最令人头疼的就是猫咪挑食不吃猫粮&#xff0c;为什么猫咪挑食不吃猫粮&#xff1f;猫咪挑食应该怎么办&#xff1f;今天为大家分享一个既不让咱宝贝猫咪受罪又可以改善猫咪挑食的方法。 一、为什么猫咪…

camunda7流程引擎外部任务(External Task)如何使用

camunda7流程引擎支持两种执行服务任务的方式: 内部任务&#xff1a;同步调用与流程应用程序一起部署的代码外部任务&#xff1a;在列表中提供可由员工轮询的工作单元 第一个选项可以通过委托代码&#xff08;Delegation&#xff09; 或者脚本&#xff08;Script&#xff09;…

C#,数值计算,求解微分方程的吉尔(Gear)四阶方法与源代码

1 微分方程 微分方程&#xff0c;是指含有未知函数及其导数的关系式。解微分方程就是找出未知函数。 微分方程是伴随着微积分学一起发展起来的。微积分学的奠基人Newton和Leibniz的著作中都处理过与微分方程有关的问题。微分方程的应用十分广泛&#xff0c;可以解决许多与导数…

【Micropython教程】key按键与EXTI中断

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、按键的使用1.1 按键的简介1.2 读取按键的高低电平 二、EXIT外部中断2.1 EXIT外部中断简介2.2 外部中断基础知识2.3 设置外部中断2.4 示例代码 总结 前言 M…

Linkedln领英账号限制问题|通过代理IP安全使用Linkedln

LinkedIn是跨境外贸必备的拓客工具&#xff0c;世界各地的许多专业人士都使用领英来作为发布和共享内容的主要工具&#xff0c;这使得它成为跨境出海必备的渠道工具。 但是不少做外贸的朋友都知道&#xff0c;领英账号很容易遭遇限制封禁&#xff0c;但如果善用工具&#xff0…

基于transform的scale属性,动态缩放整个页面,实现数据可视化大屏自适应,保持比例不变形,满足不同分辨率的需求

文章目录 一、需求背景&#xff1a;二、需求分析&#xff1a;三、选择方案&#xff1a;四、实现代码&#xff1a;五、效果预览&#xff1a;六、封装组件&#xff1a; 一、需求背景&#xff1a; 数据可视化大屏是一种将数据、信息和可视化效果集中展示在一块或多块大屏幕上的技…

string字符串进行分割

c标准库中&#xff0c;对string字符串并没有提供分割操作&#xff0c;需要自己手动实现此功能。 方式1&#xff1a; 采用 std::stringstream 输入字符串&#xff0c;通过getline()函数&#xff0c;来对字符串进行分割。 #include <sstream>void getSplit(std::string s…

探究前端路由hash和history的实现原理(包教包会)

今天我们来讲一讲前端中很重要的一个部分路由&#xff08;router&#xff09;&#xff0c;想必前端小伙伴对‘路由’一词都不会感到陌生。但是如果哪天面试官问你&#xff0c;能大概说一说前端路由的实现原理吗&#xff1f; 你又会如何应对呢&#xff1f; 今天勇宝就带着大家一…

移动端WEB开发之响应式布局推特

1&#xff0c;响应式开发 1.1 响应式开发原理 就是使用媒体查询针对不同宽度的设备进行布局和样式的设置&#xff0c;从而适配不同设备的目的 设备划分 尺寸区间 超小屏幕&#xff08;手机&#xff09; …

项目技术栈-解决方案-消息队列

项目技术栈-解决方案-消息队列 概念应用场景1. 异步处理 参考文章消息队列&#xff08;Message Queue&#xff09; 概念 “消息”是在两台计算机间传送的数据单位。 消息可以非常简单&#xff0c;例如只包含文本字符串&#xff1b; 也可以更复杂 &#xff0c;包括对象等。 队…

springboot+maven项目导入本地jar包,以有打包错误问题

1 本地jar包放置路径为&#xff1a; 2添加Modules File->project settings–>Modules–>Dependencies–>–>, 3 添加 Libraies 至此 项目即可成功运行。 mvn 打包错误&#xff0c;需要 运行以下命令 mvn install:install-file -Dfile${project.basedir}/s…