c语言怎么检验是不是素数

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

c语言怎么检验是不是素数

如何在 C 语言中检查素数

什么是素数?
素数是指除自身和 1 之外,不能被其他正整数整除的自然数。

C 语言中检查素数的方法

1. 暴力算法

立即学习“C语言免费学习笔记(深入)”;

遍历从 2 到 待检测数的平方根的所有整数。如果待检测数能被遍历的整数整除,则它不是素数。如果待检测数无法被任何遍历的整数整除,则它是一个素数。

代码实现:

#include #include 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;}

2. 费马小定理

对于任何素数 p 和任何整数 a,a^(p-1) % p = 1。

代码实现:

#include 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;}

3. Miller-Rabin 算法

这是检查素数的一种更有效的算法,但实现起来比较复杂。

代码实现:

#include #include #include 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;}

以上就是c语言怎么检验是不是素数的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1452357.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月18日 05:00:35
下一篇 2025年12月18日 05:00:47

相关推荐

发表回复

登录后才能评论
关注微信