C 语言中检查素数的方法有三种:暴力算法:遍历从 2 到平方根的所有整数,若能整除则非素数。费马小定理:a^(p-1) % p = 1,若恒等则为素数。Miller-Rabin 算法:更有效,但实现较复杂。

如何在 C 语言中检查素数
什么是素数?
素数是指除自身和 1 之外,不能被其他正整数整除的自然数。
C 语言中检查素数的方法
1. 暴力算法
立即学习“C语言免费学习笔记(深入)”;
代码实现:
<code class="c">#include <stdio.h>
#include <math.h>
int is_prime(int num) {
if (num <= 1) return 0;
for (int i = 2; i <= sqrt(num); i++) {
if (num % i == 0) return 0;
}
return 1;
}</code>2. 费马小定理
代码实现:
<code class="c">#include <stdio.h>
int is_prime(int num) {
if (num <= 1) return 0;
for (int i = 2; i < num; i++) {
if (pow(i, num-1) % num != 1) return 0;
}
return 1;
}</code>3. Miller-Rabin 算法
代码实现:
<code class="c">#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
int is_prime(int num) {
if (num <= 1) return 0;
if (num <= 3) return 1;
if (num % 2 == 0 || num % 3 == 0) return 0;
int s = 0;
uint64_t d = num-1;
while (d % 2 == 0) {
s++;
d /= 2;
}
for (int i = 0; i < 20; i++) {
int a = rand() % (num-1) + 1;
uint64_t x = powmod(a, d, num);
if (x == 1 || x == num-1) continue;
int j = 1;
while (j < s && x != num-1) {
x = powmod(x, 2, num);
if (x == 1) return 0;
j++;
}
if (x != num-1) return 0;
}
return 1;
}</code>以上就是c语言怎么检验是不是素数的详细内容,更多请关注php中文网其它相关文章!
C语言怎么学习?C语言怎么入门?C语言在哪学?C语言怎么学才快?不用担心,这里为大家提供了C语言速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号