Java中求质数的方法有以下几种:
埃拉托斯特尼筛法(埃氏筛法):从2开始,将所有2的倍数标记为合数,然后再找到下一个未被标记为合数的数,将其所有倍数标记为合数,重复这个过程直到找不到更多的数。
费马素性测试:对于给定的数n,随机选择一个整数a小于n,如果a的n次方对n取模结果不等于a,则n一定是合数,否则n可能是质数。重复进行这个测试多次,可以提高结果的准确性。
米勒-拉宾素性测试:与费马素性测试类似,通过随机选择一个整数a小于n,如果a的(n-1)次方对n取模结果不等于1,则n一定是合数,否则n可能是质数。重复进行这个测试多次,可以提高结果的准确性。
素数定理:根据素数定理,对于给定的数n,如果n较大,可以使用素数定理的近似公式进行判断,如果n足够大,且满足log(n) < log(10^18),则n可能是质数。
以上方法可以根据具体情况选择使用,根据所需的准确性和效率来进行权衡。