判断一个数是否为素数的代码(判断10000以内的数是不是素数)

素数(也叫质数)的数学定义为:大于1的自然数中除了1和它本身外没有其他因数的整数,常见的素数有:2,3,5,7,11,13……等,判断一个数是不是素数经常作为考试题目。先了解一下算法:设i=2,n为需要判断的数。 计算n/i 如果n/i的余数为0,则输出:n不是素数 如果n/i的余数不为0,则令i=i+1,如果此时i<n,则返回第2步,否则输出:n是素数。算法流程图:…

大家好,又见面了,我是你们的朋友全栈君。

素数(也叫质数)的数学定义为:大于1的自然数中除了1和它本身外没有其他因数的整数,常见的素数有:2,3,5,7,11,13……等,判断一个数是不是素数经常作为考试题目。

 

算法

算法1

算法描述:

  1. 令i=2,n为需要判断的数;
  2. 如果n<=1,则输出:n不是素数,如果n>=2,则判断n是否等于2,如果n=2,则输出:n是素数,否则执行第3步骤;
  3. 判断i<n是否成立,如果成立则计算n%i,否则输出:n是素数;
  4. 如果n%i为0,则输出:n不是素数;
  5. 如果n%i不为0,则令i=i+1,同时返回第3步。

算法流程图:

判断一个数是否为素数的代码(判断10000以内的数是不是素数)

                                                                                          图1

图1中的红线是为了区分两个相交的箭头,算法中要特别注意对n<=1和n=2的情况进行处理。

该算法的时间复杂度为:

最好:O(1),此时走图1中左边两条路径,不进循环

最差:O(n-2),此时进入取模循环体中

 

算法2

该算法是对算法1的改进

算法描述:

  1. 令i=2,n为需要判断的数;
  2. 如果n<=1,则输出:n不是素数,如果n>=2,则判断n是否等于2或3,如果n=2 || 3,则输出:n是素数,否则执行下一步;
  3. 判断i<=sqrt(n)是否成立,如果成立则计算n%i,如果不成立,则输出:n是素数;
  4. 如果n%i的为0,则输出:n不是素数;
  5. 如果n%i不为0,则令i=i+1,同时返回第3步。

算法流程图:

判断一个数是否为素数的代码(判断10000以内的数是不是素数)

                                                                       图2

算法时间复杂度分析:

最好:O(1),此时走图1中左边两条路径,不进循环

最差:O(sqrt(n)-1),此时进入取模循环体中

 

因为当n>3时,sqrt(n)-1<n-2,n为正整数。所以算法2的整体时间复杂度比算法1底,相比之下,算法2更有优势。

代码

算法2的代码实现,使用Java编程语言

 public static boolean isPrime(int n) {
        //java的基本数据类型中除了char其他都是无符号类型,并且char只能是无符号类型,即Java不提供unsigned关键字
        int i = 2;
        boolean flag = true;
        if (n <= 1) {//这是Java当中特有的代码,因为在Java的语法中不存在unsigned关键字
            return flag = false;
        } else {
            while (i <= sqrt(n)) {//出口1
                //出口1和出口2之间为“or”关系
                if (n % i == 0) {//出口2
                    flag = false;
                    break;
                }
                i++;
            }
        }
        return flag;
    }

代码中对n=2 || 3的判断是隐式的,在while判断语句中中,因为i的初始值为2,又sqrt(2)和sqrt(3)都小于2,所以n=2 || 3进入不了while循环,程序会返回flag的初始值true。

上面代码中的while循环可以用for替代,这样看起来更简介,具体参考博主“canmengmeng ”的文章素数的for循环实现

 

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/126042.html原文链接:https://javaforall.net

(1)
上一篇 2022年4月18日 上午8:20
下一篇 2022年4月18日 上午8:20


相关推荐

  • Intel 内部指令 — AVX和AVX2学习笔记[通俗易懂]

    Intel 内部指令 — AVX和AVX2学习笔记[通俗易懂]AVX编程基础数据类型数据类型描述__m128包含4个float类型数字的向量__m128d包含2个double类型数字的向量__m128i包含若干个整型数字的向量__m256包含8个float类型数字的向量__m256d包含4个double类型数字的向量__m256i包含若干个整型数字的向量每一种类型,从2个下划线开头,接…

    2022年5月30日
    35
  • Java中float/double取值范围与精度

    Java中float/double取值范围与精度Java 浮点数浮点数结构 要说清楚 Java 浮点数的取值范围与其精度 必须先了解浮点数的表示方法 浮点数的结构组成 之所以会有这种所谓的结构 是因为机器只认识 01 你想表示小数 你要机器认识小数点这个东西 必须采用某种方法 比如 简单点的 float 四个字节 前两个字节表示整数位 后两个字节表示小数位 这就是一种规则标准 这样就组成一个浮点数 而 Java 中浮点数采用的是 IEEE754 标准 IEE

    2026年3月19日
    2
  • C++使用curl发送post请求

    C++使用curl发送post请求发送post请求代码如下:#include<iostream>#include<string>#include<curl\curl.h>usingnamespacestd;//get请求和post请求数据响应函数size_treq_reply(void*ptr,size_tsize,size_tnmemb,void*stream)…

    2022年7月27日
    7
  • JDBC与数据库连接池

    JDBC与数据库连接池JDBC 简介 driver 类型 JDBC 连接 使用技巧 连接 短连接 长连接 连接池 池化思想 配置 基本配置 关键配置 性能配置 连接池工具 druid HikariCP flexy pool

    2026年3月18日
    2
  • sit环境和uat环境的区别_uat环境分层

    sit环境和uat环境的区别_uat环境分层介绍一下开发过程中,四个环境以及各自的功能特点,四个环境分别是:pro、pre、test、dev环境,中文名字:生产环境、灰度环境、测试环境、开发环境DEVdevelopment开发SITSystemIntegrateTest…

    2022年9月30日
    3
  • 决策引擎上线啦「建议收藏」

    决策引擎上线啦「建议收藏」决策服务基本都涵盖了信用和市场的整个生命周期管理,从客户获取、申请审批、客户管理、催收和欺诈管理等业务应用等等方面。基于这样的需求,决策引擎在此时便孕育而生。目前在风控系统上,决策引擎更是都是非常成熟稳定的模块。

    2022年6月18日
    33

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号