温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

输出所有小于等于n的素数(要求1)每行输出10个(要求2)较优的算法

发布时间:2020-07-04 04:10:38 来源:网络 阅读:1531 作者:Edward__Li 栏目:编程语言

方法:

若n是素数,则n不能被2~n的任何整数整除!

代码:

 

 

#include“stdio.h”
#include"math.h"
//判断是否为素数
bool prime(int n){
    int i;
    for(i=2;i<=(int)sqrt(n);i++){
        if(n%i==0)
        return false;
    }
    return true;
}
void main(){
    int n,i,j=0; //j累计素数个数,n指求那个数之前的素数
    printf("n:");
    scanf("%d",&n);
    printf("所求的为小于等于n的素数:\n",n);
    if(n>2){
    printf("M",2);
    j++;
    }
    for(i=3;i<=n;i+=2){
        if(prime(i)){
            printf("M",i);
            if(j!=0&&++j==0) //每10个换一行
            printf("\n");
        }
    }
    printf("\n素数一共有%d个",j);
}

 结果:

 

输出所有小于等于n的素数(要求1)每行输出10个(要求2)较优的算法


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI