Java中判断质数的方法

article/2025/9/23 13:13:23

Java中判断质数的几种方法


说明:

1.质数:又称素数。是一个大于1的自然数(最小质数为2)。除了1和它自身外,不能被其他自然数整除的数。
=>质数:用n除[2,n-1]的所有数,不能整除就是n就是质数。

2.[2,n-1]缩小到[2,√n]效果相同

原因:判断一个n(n>1,自然数)是否是质数?
n=xy,x、y为整数,n=√n√n,此时就当x,y都等于√n,x取小于√n的某整数时,若能被n整除,得到y大于√n的某整数,也能被n整除,保持乘积还是n。x、y两个约数在√n两边。判断是否素数,需要n除[2,n-1]的所有数,使用√n分为[2,√n]和[√n,n-1],n在[2,√n]有约数,在[√n,n-1]也有约数,n在[2,√n]没有约数,在[√n,n-1]也没有约数。
其实只需要[2,√n]就能起到判断质数作用。

//求100000以内的质数?class PrimeNumberTest {public static void main(String[] args) {//方法1long start = System.currentTimeMillis(); //开始时间for(int i = 2; i<=100000; i++){if(i==2){System.out.print(i+" ");}for(int j=2; j<=i-1; j++){if(i % j != 0){//不能被整除if(j != i-1){//不是最后一个数,继续遍历continue;}else{//是最后一个数System.out.print(i+" ");}}else{//遍历过程中,只要有一个数能被整除,跳出内循环break;}}}long end = System.currentTimeMillis(); //结束时间System.out.println("消耗时间" + (end - start));System.out.println();//方法2(未优化)long start1 = System.currentTimeMillis(); for(int i=2; i<=100000; i++){boolean isFlag = true;for(int j = 2; j<=i-1; j++){if(i % j == 0){isFlag = false;}}if(isFlag == true){System.out.print(i+" ");}}long end1 = System.currentTimeMillis(); System.out.println("消耗时间" + (end1 - start1));System.out.println();//方法2(优化)long start2 = System.currentTimeMillis(); for(int i=2; i<=100000; i++){boolean isFlag = true;for(int j = 2; j<=Math.sqrt(i); j++){//优化1,对质数。[2,这个数-1]->[2,√这个数]if(i % j == 0){isFlag = false;break;//优化2,对非质数。在遍历是否整除过程中,只要出现整除的,立马终止循环,不除后续的数。}}if(isFlag == true){System.out.print(i+" ");}}long end2 = System.currentTimeMillis(); System.out.println("消耗时间" + (end2 - start2));System.out.println();//方法3long start3 = System.currentTimeMillis(); laber:for(int i=2; i<=100000; i++){//对这个for循环打个标签laberfor(int j = 2; j<=Math.sqrt(i); j++){if(i % j == 0){continue laber;//不是质数,结束外层for循环的当次循环(这个数不是质数换个数继续判断)}}//执行到此处的都是质数System.out.print(i+" ");}long end3 = System.currentTimeMillis(); System.out.println("消耗时间" + (end3 - start3));}
}

方法1:在这里插入图片描述
方法2(未优化):在这里插入图片描述
方法2(优化):在这里插入图片描述
方法3:
在这里插入图片描述

可以看出方法2(优化)执行效率最快。


http://chatgpt.dhexx.cn/article/bgUsUWJ6.shtml

相关文章

C++高效的质数的判断(2种方法)

前提准备 在开始质数的讨论之前&#xff0c;我们先预备一下&#xff1a; 质数的定义&#xff1a;若一个正整数除了1和它自身之外不能被任何自然数整除&#xff0c;则该数称为质数&#xff0c;也叫素数。否则为合数。 由定义可知&#xff0c;所有小于等于1的数既不是质数&…

C语言 判断质数很简单

算法分析&#xff1a;假设对于一个正数a,如果a的约数只有两个&#xff0c;1和它本身&#xff0c;那这样数叫做素数。我们对a在2—a-1之间取余&#xff0c;如果还能找到第三个约数&#xff0c;使得余数为0&#xff0c;那a就不是素数&#xff0c;如果找不到第三个约数&#xff0c…

判断一个数是否为质数(素数)的4种方法

目录 1.什么是质数&#xff1f; 2.如何判断是否为质数&#xff1f; 方法1 方法2 方法3 方法4 1.什么是质数&#xff1f; 首先来看质数的概念&#xff1a; 质数&#xff08;Prime number&#xff09;&#xff0c;又称素数&#xff0c;指在大于1的自然数中&#xff0c;除了…

判断一个数是否为质数/素数——从普通判断算法到高效判断算法思路

定义&#xff1a;约数只有1和本身的整数称为质数&#xff0c;或称素数。 计算机或者相关专业&#xff0c;基本上大一新生开始学编程都会接触的一个问题就是判断质数&#xff0c;下面分享几个判断方法&#xff0c;从普通到高效。 1&#xff09;直观判断法 最直观的方法&#xf…

【C】C语言判断是否质数

类似帖子很多了&#xff0c;本文侧重循序渐进逐步优化的写出判断质数的代码。 1.质数定义 质数 (素数&#xff09;只能被 1 或自己整除。 同时它必须是大于 1 的整数。 1 不是质数也不是合成数。 常见的质数就是&#xff1a;2&#xff0c;3&#xff0c;5&#xff0c;7&…

判断质数(函数)

题目描述 质数是指除了1和本身之外没有其他约数的数&#xff0c;如7和11都是质数&#xff0c;而6不是质数&#xff0c;因为6除了约数1和6之外还有约数2和3。输入一个正整数&#xff0c;判断它是否为质数&#xff0c;如是质数则输出“Yes”&#xff0c;否则输出这个数的大于1的…

[C++]判断质数

最近做了几个判断质数的函数&#xff0c;记录一下&#xff1a; 一直接试除 bool is_prime3(unsigned long long n) { //slowfor (int i 2; i < n - 1; i) {if (n % i 0) {return 0;}}return 1; } note&#xff1a;比较慢 二一点优化 每次试除时其实只要除到 sqrt(n) 并且…

c++质数判断

循环和函数:质数判断 对于大于1的数,如果除了1和它本身,它不能再被其它正整数整除,那么我们说它是一个质数。要求编写程序判断给定的输入是否是质数。输入为一个整数N(1<N≤1000)。如果给出的整数N为质数,那么 输出YES;如果N不是质数,那么输出NO。

键入一个整数,判断是否是质数(两种方法)

判质数的原理就不过多赘述了&#xff0c;请移步C语言求100到500的所有质数&#xff0c;每10个数字一行打印_马拾捌的博客-CSDN博客_c语言每十个一行质数就是只能被1和他自己整除的数字第一次代码优化一个数字的因数里&#xff0c;除了1和自己以外最大的因数一定小于等于自身的一…

(三)混合边缘AI人脸对齐

目录 介绍 对齐算法 算法的实现 向检测器添加人脸对齐 修改对齐算法 下一步 在这里&#xff0c;我们将简要说明如何在Raspberry Pi上安装MTCNN、TensorFlow和Keras。然后我们在视频文件上启动人脸检测以测试性能&#xff0c;然后简要说明如何在实时模式下运行检测。最后&…

人脸对齐及关键点检测

严格定义上的人脸识别分为四个步骤&#xff1a; ①人脸检测&#xff1a;从图片中准确定位到人脸 ②人脸对齐&#xff1a; 自动定位出面部关键特征点&#xff0c; ③进行特征提取 ④对两张人脸图像的特征向量进行对比&#xff0c;计算相似度。 当今的人脸识别系统如下图所示…

人脸对齐 matlab,常用几种人脸对齐算法ASM/AAM/CLM/SDM

常用几种人脸对齐算法ASM/AAM/CLM/SDM 常用几种人脸对齐算法ASM/AAM/CLM/SDM 转载&#xff1a;http://blog.csdn.net/huneng1991/article/details/51901912 SDM原理 转载&#xff1a;http://blog.csdn.net/linolzhang/article/details/55271815 人脸对齐算法 一、ASM算法 ASM(A…

人脸识别篇---人脸对齐

人脸对齐 安装环境dlib 脚本实现运行代码实现效果运行问题 安装环境 dlib windows10安装dlib 在anaconda3下激活相应的环境 conda install -c conda-forge dlib参考 脚本实现 from imutils.face_utils import FaceAligner from imutils.face_utils import rect_to_bb impo…

人脸对齐算法常用评价标准总结

转载请注明作者和出处&#xff1a; http://blog.csdn.net/john_bh/ 文章目录 1. I O N 和 I P N ION和IPN ION和IPN2. M N E MNE MNE (the mean normalized error)3 A U C a AUCa AUCa(the area-under-the-curve)4. C E D CED CED (the Cumulative Errors Distribution curve)…

python练习3 人脸对齐以及dir、inspect的用法

一、人脸对齐 训练好的模型库文件&#xff08;替换你的模型文件位置&#xff09; import cv2 import dlib import matplotlib.pyplot as pltpath"D:\python\Lib\site-packages\cv2\photo.jpg" imgcv2.imread(path) graycv2.cvtColor(img,cv2.COLOR_BGR2GRAY)#人脸分…

人脸识别中常用的人脸检测和人脸对齐

人脸检测和人脸对齐是人脸识别的前提&#xff0c;也是进行一切人人脸相关的人脸项目的开始步骤&#xff0c;本文将从常用的人脸检测的数据集&#xff0c;以及现在公用的比较好的方法开始讲述。 人脸检测常用的数据集 人脸检测的测试数据库有很多&#xff0c;这里仅选择FDDB和…

人脸对齐—级联回归模型和深度学习模型

人脸对齐任务即根据输入的人脸图像&#xff0c;自动定位出面部关键特征点&#xff0c;如眼睛、鼻尖、嘴角点、眉毛以及人脸各部件轮廓点等&#xff0c;如下图所示。 这项技术的应用很广泛&#xff0c;比如自动人脸识别&#xff0c;表情识别以及人脸动画自动合成等。由于不同的姿…

MTCNN 人脸检测 人脸对齐

MTCNN 人脸检测 人脸对齐 flyfish 总体 Loss Stage 0:Image Pyramid 假设图片的宽度是640,高度是480 MIN_DET_SIZE12 minsize70 factor0.709 0.1714285710.709 那么金字塔窗口大小分别是 wh:110,83 wh:78,59 wh:56,42 wh:40,30 wh:28,21 wh:20,1计算过程如下 从640和480…

人脸检测实战终极:使用 OpenCV 和 Python 进行人脸对齐

使用 OpenCV 和 Python 进行人脸对齐 这篇博文的目的是演示如何使用 OpenCV、Python 和面部标志对齐人脸。 给定一组面部标志&#xff08;输入坐标&#xff09;&#xff0c;我们的目标是将图像扭曲并转换为输出坐标空间。 在这个输出坐标空间中&#xff0c;整个数据集中的所…

人脸预处理:人脸检测+人脸对齐

1 简介 对于人脸识别任务&#xff0c;人脸预处理至关重要。首先我们需要检测出图像中的人脸&#xff0c;然后通过人脸相似性变换得到对齐后的标准人脸。然后在对其进行人脸识别。在人脸识别过程中&#xff0c;往往检测到的人脸是倾斜的。相似性变换根据检测到的关键点和目标点…