题目描述 Description
输入一个正整数x(3<=x<=100000),判断x是否是质数,如果是质数则输出信息“prime”,否则输出“composite”。
输入描述 Input Description
一行一个正整数
输出描述 Output Description
输出prime或者composite
样例输入 Sample Input
13
样例输出 Sample Output
prime
数据范围及提示 Data Size & Hint
大于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;
}