#include<stdio.h>
#include<algorithm>
#include<iostream>
using namespace std;
long long multi(long long a,long long b,long long mod)
{
long long temp = a,sum = 0;
while(b)
{
if(b&1) sum = (sum + temp) % mod;
temp = (temp + temp) % mod;
b = b>>1;
}
return sum;
}
long long Modular_exponent(long long a,long long b,long long mod)
{
long long t = a % mod,r = 1;
while(b)
{
if(b & 1) r = multi(r,t,mod);
t = multi(t,t,mod); b = b>>1;
}
return r;
}
bool Miller_Rabin(long long n)
{
long long time = 10;
if(n < 2) return false;
if(n == 2) return true;
bool flag = false;
for(long long k = 0;k <= time;++k)
{
flag = false;
long long d = n - 1,r = 0,t,a = rand()%(n-2) + 2;
while((d & 1) == 0)
{
d = d>>1;
r++;
}
t = Modular_exponent(a,d,n);
if(t == 1 || t == n-1) {flag = true;continue;}
for(long long i = 1;i < r;i++)
{
t = multi(t,t,n);
if(t == 1) {flag = false;return flag;}
if(t == n-1) {flag = true;break;}
}
if(!flag) break;
}
return flag;
}
int main()
{
long long n;
while(~scanf("%lld",&n))
{
if(Miller_Rabin(n)) printf("Yes\n");
else printf("No\n");
}
return 0;
}Miller-Rabin随机判断素数
最新推荐文章于 2025-04-04 13:39:18 发布
本文介绍了一种基于Miller-Rabin算法的高效素数检测方法。该方法通过特定次数的随机测试来判断一个数是否为素数,并详细展示了核心函数的实现过程,包括快速乘法、快速幂运算等关键步骤。
部署运行你感兴趣的模型镜像
您可能感兴趣的与本文相关的镜像
ACE-Step
音乐合成
ACE-Step
ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

7932





