判断素数(质数)java

判断素数(质数)

什么是素数

素数(Prime Number),又称质数是指在大于1的自然数中,除了1和本身之外,不能被其他自然数整除的数。例如,2、3、5、7、11等都是素数。

求解思路

要判断一个数是否为素数,一种简单的方法是试除法,即从2开始逐个试除,如果能整除则不是素数。但这种方法在判断较大的数时会比较耗时。下面介绍更高效的方法。

代码思路
  • 试除法:遍历2到该数的平方根,判断该数是否能被任意一个小于等于它平方根的数整除。如果能整除,则该数不是素数;否则,该数是素数。
  • 优化思路
    • 我们只需要遍历2到该数的平方根之间的数即可,因为大于平方根的因数必然与小于平方根的因数对称。
    • 此外,在判断一个数是否为素数时,我们只需要检查是否能被2到该数的平方根之间的数整除即可。而对于大于2的偶数,它们都能被2整除,因此不可能是素数。因此,在试除时,我们可以跳过所有的偶数,直接从3开始以步长为2逐个试除。这样可以减少循环的次数,提高算法效率。
复杂度分析
  • 时间复杂度:假设待判断的数为n,则试除法的时间复杂度为O(√n),因为我们只需遍历2到√n之间的数进行判断。
  • 空间复杂度:该算法的空间复杂度为O(1),因为只需要常数级别的额外空间来存储临时变量。
Java实现

下面是判断素数的Java代码实现:

java 复制代码
public class PrimeNumber {
    // 判断一个数是否为素数
    public static boolean isPrime(int num) {
        if (num <= 1) {
            return false;
        }
        if (num == 2) {
            return true;
        }
        if (num % 2 == 0) {
            return false;
        }
        for (int i = 3; i * i <= num; i += 2) {
            if (num % i == 0) {
                return false;
            }
        }
        return true;
    }

    public static void main(String[] args) {
        // 测试
        int[] testCases = {2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41};
        for (int num : testCases) {
            System.out.println(num + " 是素数吗?" + isPrime(num));
        }
    }
}
相关推荐
biubiuibiu4 分钟前
JavaScript核心概念深度解析:位运算与短路逻辑
开发语言·javascript·ecmascript
2401_849644856 分钟前
C++代码重构实战
开发语言·c++·算法
葡萄城技术团队7 分钟前
Hurley:用 Rust 打造的高性能 HTTP 客户端 + 压测工具
开发语言·http·rust
sthnyph8 分钟前
Spring Framework 中文官方文档
java·后端·spring
带刺的坐椅15 分钟前
Snack4 Json 流式解析与自动结构修复深度指南
java·llm·json·jsonpath
2301_8154829316 分钟前
C++与WebAssembly集成
开发语言·c++·算法
zb2006412018 分钟前
Spring Boot 实战篇(四):实现用户登录与注册功能
java·spring boot·后端
码云数智-大飞19 分钟前
React vs Vue:虚拟 DOM 的殊途同归与优化哲学
开发语言
机器学习之心HML21 分钟前
考虑气象因素的贝叶斯优化短期电力负荷预测研究,MATLAB代码
开发语言·matlab
我命由我1234523 分钟前
Android 多进程开发 - FileDescriptor、Uri、AIDL 接口定义不能抛出异常
android·java·java-ee·kotlin·android studio·android-studio·android runtime