Java中判断素数的五种有效方法

 更新时间:2026年01月07日 08:28:17   作者:AaronYu_  
本文介绍了五种在Java中判断素数的有效方法,包括从2到x-1测试、排除偶数、仅测试到sqrt(x),以及使用素数表和计算机思维方式的高级策略,文章详细解释了每种方法的时间复杂度和实现细节,需要的朋友可以参考下

Java 中判断素数我们有很多方法,每种方法时间复杂度也不一样。今天我汇总了一下,分享给大家。既可以输出前 50 或 n 个素数,也可以判断 100 (或 n) 以内的素数。

1. 从 2 到 x-1 测试是否可以整除

Scanner in = new Scanner(System.in);

int x = in.nextInt();
boolean isPrime = true;
if ( x == 1)
{
	isPrime = false;
}
for( int i = 2; i< x; i++)
{
	if(x % i ==0)
	{
		isPrime = false;
		break;
	}
}
if( isPrime)
{
	System.out.println(x +"是素数");
	
}
else
{
	System.out.println(x+ "不是素数");
}

2. 去掉偶数后,从 3 到 x-1, 每次加 2

改进版,时间复杂度为 O(n/2)

if(x ==1 || x %2 ==0 && x !=2 )
{
	isPrime = false;
}
else
{
	for(int i =2; i<x; i +=2)
	{
		if( x % i == 0)
		{
			isPrime = false;
			break;
		}
	}
}
if( isPrime)
{
	System.out.println(x +"是素数");
	
}
else
{
	System.out.println(x+ "不是素数");
}

3. 2 方法上的改进版,只需到 sqrt(x) 即可以

数学上可以证明,sqrt(x) 即 x 的平方根
时间复杂度为 O(sqrt(n))

if(x ==1 || x %2 ==0 && x !=2 )
{
	isPrime = false;
}
else 
{
	for( int i =3; i< Math.sqrt(x); i+=2)
	{
		if( x % i == 0)
		{
			isPrime = false;
			break;
		}
	}
}
if( isPrime)
{
	System.out.println(x +"是素数");	
}
else
{
	System.out.println(x+ "不是素数");
}

4. 找出前 50 个素数

判断是否能被已知的的且 <x 的素数整除
这个方法可扩展性很强,建议掌握。

int [] primes = new int[50];
primes[0] =2;
int cnt =1;
Main:
for(int x= 3; cnt<primes.length; x++)
{
	for(int i = 0; i< cnt; i++)
	{
		if( x % primes[i] == 0)
		{
			continue Main;
		}
	}
	primes[cnt++] = x;
	
}
for ( int k: primes)
{
	System.out.print(k+ " ");
}

5. 用计算机的语言去思考

构造素数表,构造 n 以内的素数表

原理:

  1. 令 x =2;
  2. 将 2x、3x、4x 直至 ax<n 的数标记为非素数
  3. 令 x 为下一个没有被标记为非素数的数,重复 2;直至所有的数都已尝试完毕。
boolean[] isPrime = new boolean[100];
for( int i =2; i< isPrime.length; i++)
{
	isPrime[i] = true;
}
for(int i =2; i<isPrime.length; i++)
{
	if( isPrime [i])
	{
		for(int k=2; i*k < isPrime.length; k++)
		{
			isPrime[i*k] = false;
		}
	}
}
for( int i = 0; i<isPrime.length; i++)
{
	if(isPrime[i])
	{
		System.out.print(i+ " ");
	}
}

好了,以上便是五种判断素数的方法,第四种和第五种方法要求掌握,相信你能很快学会,一定一定要上手实操,debug 一下,你就懂了。

到此这篇关于Java中判断素数的五种有效方法的文章就介绍到这了,更多相关Java判断素数方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • springboot开发扩展springmvc实现解析

    springboot开发扩展springmvc实现解析

    这篇文章主要介绍了springboot开发扩展springmvc实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • java题解LeetCode454.四数相加示例

    java题解LeetCode454.四数相加示例

    这篇文章主要为大家介绍了java题解LeetCode454.四数相加示例思路解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • JDK15正式发布(新增功能预览)

    JDK15正式发布(新增功能预览)

    这篇文章主要介绍了JDK15正式发布,新增功能预览,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2020-09-09
  • spring 定时任务@Scheduled详解

    spring 定时任务@Scheduled详解

    这篇文章主要介绍了spring 定时任务@Scheduled的相关资料,文中通过示例代码介绍的很详细,相信对大家的理解和学习具有一定的参考借鉴价值,有需要的朋友们下面来一起看看吧。
    2017-01-01
  • Java JDBC连接Kerberos认证的HIVE和Impala方式

    Java JDBC连接Kerberos认证的HIVE和Impala方式

    本文主要介绍了HiveJDBC和ImpalaJDBC的使用方法,包括版本对应、Maven安装、主机名配置、端口开通、JDBC连接和Kerberos认证等
    2025-02-02
  • java 类加载与自定义类加载器详解

    java 类加载与自定义类加载器详解

    本文主要介绍了java 类加载与自定义类加载器。具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • Java导出多个excel表打包到zip文件中供客户端另存为窗口下载实现方法

    Java导出多个excel表打包到zip文件中供客户端另存为窗口下载实现方法

    最近的项目有一个导出汇总数据的要求,考虑到用户软件的差异,所以要分别导出xls以及xlsx并且打包提供下载,下面这篇文章主要给大家介绍了关于Java导出多个excel表打包到zip文件中供客户端另存为窗口下载的实现方法,需要的朋友可以参考下
    2023-12-12
  • 解决Dubbo应用启动注册ZK获取IP慢的原因之一

    解决Dubbo应用启动注册ZK获取IP慢的原因之一

    这篇文章主要介绍了解决Dubbo应用启动注册ZK获取IP慢的原因之一,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • 解读maven项目的打包方式

    解读maven项目的打包方式

    这篇文章主要介绍了关于maven项目的打包方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • java仅用30行代码就实现了视频转音频的批量转换

    java仅用30行代码就实现了视频转音频的批量转换

    这篇文章主要介绍了java仅用30行代码就实现了视频转音频的批量转换,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04

最新评论