判断素数的快速算法 sqrt()

我们在日常判断素数的程序中常用到如下代码

//判断数num是不是素数
for(i=2;i<num;i++){

    if(num%i==0)
         return 0;

    return 1;
}

这样写无疑是没有问题的,但是我们实际做题可能会有算法时间复杂度的要求,或者说数据大的时候我们会等很久,算法效率低,那么有没有一种好的算法可以更快地判断是不是素数呢?

当然了,先附上代码段

//判断数num是不是素数
for(i=2;i<=sqrt(num);i++){

    if(num%i==0)
         return 0;

    return 1;
}

sqrt()函数是用来判断开根号的,那么我们这样用是为何呢?

比如想判断20是不是素数,我们都知道素数是除了1和数本身没有其他公约数的数,我们看,20可以分成如下公因子:

如果我们用老办法i=2到20一个一个判断是可以,但是没有必要

因为,我们可以使用sqrt来判断

//判断数20是不是素数
for(i=2;i<=sqrt(20);i++){

    if(num%i==0)
         return 0;

    return 1;
}

 我们看到sqrt(20)的值是4.47...

其实我们只需要判断前半段就行,因为有2肯定有10,有4肯定有5

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

.阿Q.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值