輸入一個正整數x(3<=x<=100000),判斷x是否是質數,如果是質數則輸出信息“prime”,否則輸出“composite”。
一行一個正整數
輸出prime或者composite
13
prime
大於2並且小於100000
推薦一個博客:點擊打開鏈接(裏面有多個素數判定和篩法)
下面附上代碼:
#include<stdio.h>
#include<string.h>
using namespace std;
int tab[]={2, 3, 5, 7};
long long qpow(int a, int b, int r) //(a^b)%r 快速冪取模
{
long long ret = 1, tmp = a;
while(b)
{
if (b&1)
ret = ret*tmp%r;
tmp = tmp*tmp%r;
b >>= 1;
}
return ret;
}
bool Miller_Rabbin(int n, int a)//米勒拉賓素數測試
{
int r = 0, s = n-1, j;
long long k;
if(n%a == 0) return false;
while((s&1) == 0)
{
s >>= 1;
r++;
}
k = qpow(a, s, n);
if(k == 1) return true;
for (j = 0; j < r; j++, k=k*k%n)
if (k == n-1)
return true;
return false;
}
bool Isprime(int n)//判斷是否是素數
{
for (int i = 0; i < 4; i++)
{
if (n == tab[i])
return true;
if (!Miller_Rabbin(n, tab[i]))
return false;
}
return true;
}
int main()
{
int n;
scanf("%d", &n);
if(Isprime(n)) printf("prime\n");
else printf("composite\n");
return 0;
}