Miller_Rabin 学习笔记

费马小定理:对于任意一个质数满足:ap11(modp)

二次探测:对于任意一个奇质数满足:x21(modp) 的解为 x=1x=p1

将两个定理结合起来,设 p1=u×2t,那么计算出 au 次方后不断进行平方计算,如果某次平方后得到了 1 并且平方的数不为 1p1,那么 p 肯定不是质数。

据说 a 选取前 13 个质数就行了,也可以使用下面程序给的数字列表。注意特判偶数和小于 3 的情况

int prime(LL n)
{
	if(n<3||n%2==0)
		return n==2;
	LL t=n-1;
	int s=0;
	while(!(t&1))
		t>>=1,s++;
	static const int pr[]={2,325,9375,28178,450775,9780504,1795265022};
	for(int i=0;i<7;i++)
	{
		int x=pr[i];
		LL v=pown(x,t,n);
		if(v==1||!v||v+1==n)
			continue;
		for(int j=1;j<=s;j++)
		{
			v=(LLL)v*v%n;
			if(j^s&&v==n-1)
			{
				v=1;
				break; 
			}
			if(v==1)
				return 0;
		}
		if(v^1)
			return 0;
	}
	return 1;
}
···
posted @   灰鲭鲨  阅读(12)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示