java nextprime,查找下一个质数的最佳方法(Java)

I was asked to write a program to find next prime number in an optimal way. I wrote this code, but I could not find an optimal answer to it. Any suggestions?

public static int nextPrime(int input) {

input++;

//now find if the number is prime or not

for(int i=2;i

if(input % i ==0 ) {

input++;

i=2;

}

else{

continue;

}

}

return input;

}

解决方案

public int nextPrime(int input){

int counter;

input++;

while(true){

int l = (int) sqrt(input);

counter = 0;

for(int i = 2; i <= l; i ++){

if(input % i == 0) counter++;

}

if(counter == 0)

return input;

else{

input++;

continue;

}

}

}

There is no need to check up on input number. It is enough to check up to the square root of a number. Sorry, I didn't remember the theorem name. Here we are incrementing the input for next prime.

The time complexity of this solution O(n^(3/2)).

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值