java如何判断一个数是否是素数(质数)

判断一个数是否是素数是一个常见的算法问题,下面是用java编写的实现方法:

1.判断算法

判断一个数x是否为素数的方法是判断x是否能被2~sqrt(x)范围内的整数整除。如果有一个数能够整除x,那么x就不是素数,否则x就是素数。

示例代码:

public static boolean isPrime(int x) {
    if (x < 2) {  // 小于2的数都不是素数
        return false;
    }
    for (int i = 2; i <= Math.sqrt(x); i++) {
        if (x % i == 0) {   // 能够整除
            return false;
        }
    }
    return true;
}

2.测试算法

为了测试isPrime算法的正确性,我们可以编写一个程序,用于判断指定范围内的所有整数是否为素数,并输出结果。

示例代码:

public static void main(String[] args) {
    int n = 100;
    System.out.printf("2~%d的素数:\n", n);
    for (int i = 2; i <= n; i++) {
        if (isPrime(i)) {
            System.out.print(i + " ");
        }
    }
}

输出结果:

2~100的素数:
2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 

上述程序会输出2~100的素数,结果与数学事实相符。因此可以证明isPrime算法的正确性。

3.优化算法

在调用isPrime算法时,我们只需要判断2~sqrt(x)范围内是否有数能够整除x,因此可以做个小优化:只需判断2和所有奇数是否能够整除x即可,因为偶数都能够被2整除。

修改isPrime算法:

public static boolean isPrime(int x) {
    if (x < 2) {  // 小于2的数都不是素数
        return false;
    }
    if (x == 2 || x == 3) {  // 2和3都是素数
        return true;
    }
    if (x % 2 == 0) {  // 偶数都不是素数
        return false;
    }
    for (int i = 3; i <= Math.sqrt(x); i += 2) {
        if (x % i == 0) {   // 能够整除
            return false;
        }
    }
    return true;
}

这个修改后的算法将只会判断2和所有奇数是否能够整除x,从而加快了算法的执行速度。

示例代码:

public static void main(String[] args) {
    int n = 100;
    System.out.printf("2~%d的素数:\n", n);
    for (int i = 2; i <= n; i++) {
        if (isPrime(i)) {
            System.out.print(i + " ");
        }
    }
}

输出结果:

2~100的素数:
2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 

可以看到,输出结果与前面的测试结果相同,但是这个算法的执行速度要更快。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:java如何判断一个数是否是素数(质数) - Python技术站

(0)
上一篇 2023年5月26日
下一篇 2023年5月26日

相关文章

  • Java日常练习题,每天进步一点点(41)

    首先我需要说明一下,题目“Java日常练习题,每天进步一点点(41)”是一系列的Java编程练习题。这些练习题旨在帮助Java初学者逐步掌握 Java 编程语言和面向对象的编程思想。 这一系列的练习题包含41道题目,每道题目都是一个小问题,每天完成一道,逐步提高自己的编程能力。 在攻略中,我将解释一下如何通过完成这道题目来练习Java编程,并提高自己的编程技…

    Java 2023年5月23日
    00
  • java日期格式化SimpleDateFormat的使用详解

    Java日期格式化SimpleDateFormat的使用详解 概述 在Java编程中,我们经常需要将日期时间类型的数据格式化成我们需要的字符串格式。Java提供了一个SimpleDateFormat类,可以帮助我们将日期时间类型的数据格式化为指定的字符串格式。 SimpleDateFormat类可以在Java的java.text包中找到,它是一个具有丰富功能…

    Java 2023年5月20日
    00
  • Android 运用@JvmName解决函数签名冲突问题详解

    当我们在 Kotlin 中定义具有相同名称、相同参数但返回值类型不同时的函数时,编译器会自动为这些函数生成不同的 JVM 签名。然而,在某些情况下,我们可能需要使用相同的 JVM 签名,例如与 Java 互操作、使用反射或 JNI。这时就需要用到 @JvmName 注解来解决函数签名冲突问题。 @JvmName 注解的作用是为指定的 Kotlin 函数或属性…

    Java 2023年5月26日
    00
  • Java数组与字符串深入探索使用方法

    Java数组与字符串深入探索使用方法 一、数组 1. 定义 Java数组是一个可以容纳固定数量元素的容器,它可以被认为是一个有序的元素列表。数组中的每个元素都有唯一的索引号来标识它们在数组中的位置。数组可以是任何类型,包括基本类型和引用类型。 2. 声明 在Java中,声明一个数组需要指定如下信息:- 数组的类型:数组中元素的类型(int、double、St…

    Java 2023年5月26日
    00
  • Spring入门基础之依赖注入

    Spring入门基础之依赖注入 本文将详细讲解Spring框架入门基础之依赖注入。我们将探讨什么是依赖注入,为什么需要它,以及如何在Spring中实现依赖注入。本文也会提供一些示例来说明如何在Spring应用程序中使用依赖注入。 什么是依赖注入 依赖注入(Dependency Injection,简称DI)是一种设计模式,它可以使对象之间的依赖关系更加松散,…

    Java 2023年5月19日
    00
  • 详解spring boot应用启动原理分析

    详解Spring Boot应用启动原理分析 Spring Boot是一个流行的Java框架,可以帮助开发人员快速构建和部署应用程序。在本文中,我们将详细讲解Spring Boot应用启动的原理分析,包括Spring Boot的自动配置、启动流程、应用上下文等。 Spring Boot的自动配置 Spring Boot的自动配置是Spring Boot的核心特…

    Java 2023年5月14日
    00
  • Java创建线程的两种方式

    当需要创建线程时,Java提供了两种方式:使用Thread类创建线程和实现Runnable接口创建线程。下面我们分别讲解这两种方式的使用方法。 1. 使用Thread类创建线程 Thread类是Java中用于创建和操作线程的基本类。使用Thread类创建线程可以直接关联想要启动的线程代码,并通过start()方法启动新线程。 示例1:继承Thread类创建线…

    Java 2023年5月18日
    00
  • Spring中使用atomikos+druid实现经典分布式事务的方法

    Spring是一个非常流行的Java框架,可以用于构建各种类型的应用程序,包括分布式应用程序。在分布式应用程序中,经典的分布式事务是非常重要的,它可以确保整个事务的一致性和完整性。Atomikos和Druid是常用的分布式事务解决方案,它们都有很多优点,例如可靠性、高性能和灵活性等。下面是如何在Spring中使用Atomikos和Druid实现经典分布式事务…

    Java 2023年5月20日
    00
合作推广
合作推广
分享本页
返回顶部