『转载』判断一个正整数是不是素数,时间复杂度为O(根号n)

原文链接:https://blog.csdn.net/liangdagongjue/article/details/77895170#commentsedit

PS:新手上路,实在找不到怎么转载,所以只能模仿某平台在名字前加转载两个字了。虽然征得原文博主同意对这篇文章进行转载,但是,由于找不到转载选项,内心还是忐忑不安。如果原文博主觉得这样不合适的话,您言语一声,我把这篇文章删掉哈~ 另外对原文内容有些许形式上的改动。

    @判断一个数是不是素数最简单直接的方法就是从素数的定义出发。检查1~n之间的所有数,从中找出n这个数的所有因子,检查因子个数是否为两个。如果正好是两个因子,则为素数,否则为非素数。这样该算法的时间复杂度是O(n)。

    @但是我们要得到根号n的时间复杂度,所以我们要进行改善,经过仔细的思考观察,发现有以下几个改善的途径。 

    @没有必要检查所有的因子,只要发现任何一个大于1小于n的因子,就能停下来报告n不是素数。 

    @一旦函数已经检查了n是否能被2整除,就不需要检查是否能被其他偶数整除。如果n能被2整除,程序就停下来,报告n不是素数。如果n不能被2整除,那么它也不可能被4或6或其他偶数整除。因此,isPrime只需要检查2和奇数。但注意有个特例,2能被2整除,但2是素数。
    @该问题不需要检查到n为止。实质上,它可以在一半的地方就停止,因为任何大于n/2的值不可能被n整除。然而再进一步思考一下,还可以证明,该程序不需要试探任何大于n的平方根的因子。当n能被某一个整数d1整除时,那么就肯定还有另一个数d2能被它整除,即n=d1*d2,如果其中一个大于n的平方根,另一个一定小于n的平方根。因此如果n有任何因子,肯定有一个小于或等于n的平方根。这就意味着程序中的for循环的次数i<=根号n

#include <stdio.h>
#include <math.h>

int IsPrime(int n)
{
	if(n<1)
		return -1;
	if(n==1)
		return 1;
	if(n==2)
		return 1;
	if(n%2==0)
		return 0;
	int end=sqrt(n)+1;
	int i;
	for(i=3; i<end; ++i)
		if(n%i==0)
			return 0;
	return 1;
}

int main()
{
	int n;
	scanf("%d", &n);
	if(IsPrime(n)==-1)
		printf("Please to insure the number which you inputed is equal or greater than 1 and is integer.\n");
	else if(IsPrime(n)==0)
		printf("%d is not a Prime.\n", n);
	else 
		printf("%d is a Prime!\n", n);
	return 0;
}

  

 

转载于:https://www.cnblogs.com/ozxics/p/10718843.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值