判断一个数是否为素数的代码(判断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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • gzip解压报错_解压文件报错怎么办

    gzip解压报错_解压文件报错怎么办用文本方法传输一个net-snmp-5.6.1.1.tar.gz去linux,结果报错,

    2025年9月26日
    3
  • java心得体会_初学java之心得体会

    java心得体会_初学java之心得体会0.前言从学习java以来,已经进行过三次pta作业的训练。虽然每次作业的完成都遇到了些许困难和障碍,不是一帆风顺的,但通过自己的摸索,实践,总能完成作业要求,每次作业之后都有不同的收获。这些新的收获告诉我,实践出真知,动手会学习到更多东西。总结前面的三次作业,我发现面向对象程序设计这种语言不再那么神秘,我相信马上就能看到揭开神秘面纱后的的它。1.作业过程总结(1).总结三次作业的知识迭代关系第一…

    2022年7月9日
    20
  • C语言描述 动态规划 背包问题

    C语言描述 动态规划 背包问题动态规划作为不同于其他类型的问题,有着它自己的解题思路以及模型,以下将围绕模型以及解题思路两方面进行讲解。1.模型:有已知推到未知,是我们常用的解题思路,好比数独中如果我们有了1~8那么剩下的格子必然是9了。动态规划也是这样的思路,眼下我们有一堆货物和一个容量有限的背包,那么如何装才能利益最大化便是我们需要考虑的问题。也就是背包问题。仔细思考,不难发现,每个物品都只有0与1(0表示不装,1表示装入)两个状态,那么一串二进制数就可以表示物品的装配方案(如0101表示只带上第2、4件物品)由此必有2

    2022年7月26日
    4
  • 图像降噪算法——从BM3D到VBM4D

    图像降噪算法——从BM3D到VBM4D图像降噪算法——BM3D图像降噪算法——BM3D1.基本原理2.C++代码实现3.结论图像降噪算法——BM3DBM3D是目前非AI降噪算法中最优的算法之一,其降噪效果确实非常惊艳,网上的资料也相对较多,我觉得写得最好的一篇博客是通俗语言说BM3D,这个博主应该是个搞图像处理的大佬,对原理理解得比较深,这里我对BM3D进行一个简单总结,然后扒了一个C++实现对接口进行了修改,移植到我自己的工程里(因为实在是忙得没时间自己复现一遍)1.基本原理2.C++代码实现3.结论…

    2022年6月5日
    65
  • windows socket编程c语言_网络编程socket

    windows socket编程c语言_网络编程socket文章目录简单介绍Socket1 WindowsSockets 简介2 套接字的两种主要形式3 在 VC 下开发套接字程序3. 1 在 VC 下开发套接字程序的基本步骤3. 2 回调函数的使用3. 3 利用多线程技术来开发网络通信3. 4 使用多线程进行套接字编程时应注意同步问题代码实现客户端服务端简单介绍Socket1 WindowsSockets 简介Windows sockets(简称 …

    2022年8月18日
    11
  • C++ 编程之QueryInterface函数(一)

    C++ 编程之QueryInterface函数(一)前言组件对外公布的是接口;一个组件可以实现多个接口,也就是说可以对外公布多个接口,之前也总结过了,你很少会100%的去完全了解一个组件的所有接口,就像你去学习编程一样,你几乎不可能去成为编程中的全才。那么,既然我们不能去完全的了解一个组件提供的所有接口,那么我们在实际开发中,如何去判断一个组件是否提供对应的接口呢?看文档?是的,是个好主意,在文档的海洋,找到一个知识点,真的很难,浪费时间和

    2022年7月22日
    13

发表回复

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

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