java编程实现求质数与因式分解代码分享

下面是 "Java编程实现求质数与因式分解代码分享" 的完整攻略。

目录

  1. 介绍
  2. 求质数的代码实现
  3. 因式分解的代码实现
  4. 示例说明
  5. 总结

介绍

本文将介绍Java编程实现求质数与因式分解的代码。当我们需要判断一个数是不是质数时,我们可以使用质数的定义:只有1和该数本身能够整除它,它才是质数。因式分解是指将一个数分解成几个互质的整数乘积的形式。这里我们使用两种算法实现求质数:暴力算法、埃氏筛法以及一种算法实现因数的分解。

求质数的代码实现

暴力算法

暴力算法是从2开始枚举所有比目标数小的正整数,逐一判定是否为目标数的因数,时间复杂度为O(N)。

public static boolean isPrime(int n) {
    if (n <= 1) {
        return false;
    }
    for (int i = 2; i * i <= n; i++) {
        if (n % i == 0) {
            return false;
        }
    }
    return true;
}

埃氏筛法

埃氏筛法是一种筛选法,它的思想是从小到大枚举每个质数,将质数的倍数都标记成合数,以此类推,直到枚举完所需范围的所有数,时间复杂度为O(N*log(log(N)))。

public static boolean[] sieveOfEratosthenes(int n) {
    boolean[] primes = new boolean[n + 1];
    Arrays.fill(primes, true);
    primes[0] = false;
    primes[1] = false;
    for (int i = 2; i * i <= n; i++) {
        if (primes[i]) {
            for (int j = i * i; j <= n; j += i) {
                primes[j] = false;
            }
        }
    }
    return primes;
}

因式分解的代码实现

public static List<Integer> factorize(int n) {
    List<Integer> factors = new ArrayList<>();
    for (int i = 2; i * i <= n; i++) {
        while (n % i == 0) {
            factors.add(i);
            n /= i;
        }
    }
    if (n > 1) {
        factors.add(n);
    }
    return factors;
}

示例说明

示例1:求100内的质数

boolean[] primes = sieveOfEratosthenes(100);
for (int i = 0; i <= 100; i++) {
    if (primes[i]) {
        System.out.println(i);
    }
}

输出结果:

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:将20分解为质因数的乘积

List<Integer> factors = factorize(20);
System.out.println(factors);

输出结果:

[2, 2, 5]

总结

本文分享了Java编程实现求质数与因式分解的代码的攻略,介绍了求质数的两种算法实现以及因式分解的一种算法实现。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:java编程实现求质数与因式分解代码分享 - Python技术站

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

相关文章

  • Java线程池的几种实现方法和区别介绍实例详解

    Java线程池的几种实现方法和区别介绍 什么是线程池 在线程池中,线程的创建和销毁都由线程池管理器来处理,线程池中包括一组线程,线程池会根据配置的参数来动态调整线程池中线程的数量。线程池中的线程可以被多个任务共享,使线程的创建和销毁开销及竞争锁等问题得以优化。 为什么要使用线程池 线程池的主要目的是为了控制并发执行的线程数,有以下几个优点: 降低线程的创建和…

    Java 2023年5月18日
    00
  • JAVA中list,set,数组之间的转换详解

    JAVA中List、Set、数组之间的转换详解 在JAVA编程中,经常需要对不同类型的集合进行转换。常用的集合类型有List、Set、数组,它们在功能和使用方式上都有所不同。本文将详细讲解List、Set、数组之间的转换方法及示例说明,让您在实际开发中能够快速灵活地应用。 List转换成数组 将List转换成数组需要使用到List的toArray()方法,示…

    Java 2023年5月26日
    00
  • Java实现学生选课管理系统

    Java实现学生选课管理系统 简介 学生选课管理系统是一个典型的管理信息系统,它可以为学校提供在线选课服务,方便学生和教师进行选课和管理。Java语言是一种高性能、跨平台的编程语言,它具有很强的可扩展性和稳定性,非常适合开发学生选课管理系统。 开发环境 JDK 1.8 Eclipse MySQL 实现步骤 步骤1:创建数据库 学生选课系统需要一个数据库来存储…

    Java 2023年5月23日
    00
  • IntelliJ IDEA设置JVM运行参数的操作方法

    下面是详细的 “IntelliJ IDEA设置JVM运行参数的操作方法”攻略: 什么是JVM运行参数? JVM运行参数指定了在Java应用程序内部运行时,JVM使用的命令行参数。这些参数可以用于调整JVM的行为和性能,例如内存分配,垃圾回收策略,线程数等。在Java应用程序中,可以通过设置JVM运行参数更好地配置JVM,以来优化应用的性能和稳定性。 Inte…

    Java 2023年5月19日
    00
  • 玩转SpringBoot中的那些连接池(小结)

    玩转SpringBoot中的那些连接池(小结) 连接池是每个Web应用中必不可少的组件,Spring Boot中默认提供了大量连接池实现,例如HikariCP、Tomcat JDBC、Commons DBCP2等等。本文将介绍这些连接池的优缺点,帮助开发者选择适合自己应用的连接池。 HikariCP HikariCP是Spring Boot中默认的连接池实现…

    Java 2023年5月19日
    00
  • Java Calendar日历与Date日期的相互转换详解

    下面是“Java Calendar日历与Date日期的相互转换详解”的完整攻略。 标题 Java Calendar日历与Date日期的相互转换详解 概述 Java中常用的时间类型有两种: Calendar和Date。在Java项目中,有时需要在这两种类型之间进行转换。本文将详细介绍如何将Calendar和Date互相转换。 Calendar转换为Date C…

    Java 2023年5月20日
    00
  • java编程中拷贝数组的方式及相关问题分析

    下面是关于 “java编程中拷贝数组的方式及相关问题分析” 的完整攻略。 一、概述 在 Java 编程中,拷贝数组是一项非常重要的操作。它允许我们创建拷贝而非引用数组,这样我们就可以在更改数组内容的过程中保持原数组不变。在这篇攻略中,我们将探讨拷贝数组的不同方式以及如何使用每种方式。 二、使用 System 类的 clone() 方法 System 类的 c…

    Java 2023年5月26日
    00
  • 详解Spring Boot 目录文件结构

    下面是详解Spring Boot目录文件结构的攻略。 目录文件结构 作为一款快速构建Java Web应用的框架,Spring Boot提供了一套默认的目录结构,旨在帮助开发人员快速搭建应用并进行开发,其目录文件结构如下: project ├── src/main/java │ └── com/example/demo │ ├── controller │ ├…

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