Fermat素性检测算法C语言
时间: 2023-07-19 12:33:07 浏览: 242
下面是 Fermat 素性检测算法的 C 语言实现:
```c
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <math.h>
// 计算 a 的 b 次方对 c 取余的结果
int mod_pow(int a, int b, int c) {
int res = 1;
while (b > 0) {
if (b & 1) {
res = (res * a) % c;
}
a = (a * a) % c;
b >>= 1;
}
return res;
}
// Fermat 素性检测算法
int fermat(int n, int k) {
if (n == 1) {
return 0;
}
for (int i = 0; i < k; i++) {
int a = rand() % (n - 1) + 1;
if (mod_pow(a, n - 1, n) != 1) {
return 0;
}
}
return 1;
}
int main() {
int n, k;
printf("请输入一个正整数:");
scanf("%d", &n);
printf("请输入测试次数:");
scanf("%d", &k);
if (fermat(n, k)) {
printf("%d 可能是素数\n", n);
} else {
printf("%d 不是素数\n", n);
}
return 0;
}
```
其中,`mod_pow` 函数用于计算一个数的幂次,`fermat` 函数是 Fermat 素性检测算法的实现。在 `main` 函数中,首先输入待测试的正整数 `n` 和测试次数 `k`,然后调用 `fermat` 函数进行素性检测,并输出检测结果。
阅读全文