C语言求素数

 我来答
名字叫难忘啊DM
高粉答主

2020-02-19 · 醉心答题,欢迎关注
知道答主
回答量:5.8万
采纳率:3%
帮助的人:2807万
展开全部
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cylz0703
2018-12-12 · TA获得超过3.4万个赞
知道大有可为答主
回答量:1.8万
采纳率:83%
帮助的人:4329万
展开全部
求多大范围内的素数,需要具体描述一下,有什么具体要求,请补充。
追答
素数改定判定,参考代码如下:
#include
#include
int isPrime(int x)
{
int i, bound;
if(x<2) return 0;
if(x==2) return 1;
if(x%2==0)//除了2以外的素数都是奇数
return 0;
bound=(int)sqrt((double)x)+1;
//防止取整带来的精度损失
for(i=3;i<bound;i=i+2)
if(x%i==0) return 0;
return 1;
}
int main(void)
{
int n=0,i;
for(i=1;i<100000;++i)
if(isPrime(i)) ++n;
printf("%d ",n);
return 0;
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2018-12-12
展开全部
#include <stdio.h>
#include <stdbool.h>
   
int main(int argc, char const *argv[])
{
    unsigned long num;
    unsigned long div;
    bool isPrime;
   
    while (scanf("%lu", &num) == 1)//从终端输入一个数,为无符号双精度。成功输入scanf返回1
    {
     if (num <= 1)
     {
     printf("%lu is not a prime.\n", num);
     continue;
     }
        for (div = 2, isPrime = true; (div * div) <= num; div++)//一个非素数数的最小公约数,必定小于等于其开根号
        {
            if (num % div == 0)//判断是否被整除
            {
                if ((div *div) != num)//判断是否为平方数
                    printf("%lu is divisible by %lu and %lu.\n",num,div,num/div);
                else
                    printf("%lu is divisible by %lu.\n",num,div);
                isPrime = false;
            }
        }
        if (isPrime)
            printf("%lu is prime.\n", num);
    }
   
    return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式