C语言编程入门:代码筛选求素数和普通求法
Vivian 2018-06-04 来源 : 阅读 1073 评论 0

摘要:本文主要向大家介绍了C语言编程入门的代码筛选求素数和普通求法,通过具体的代码向大家展示,希望对大家学习C语言编程入门有所帮助。

    本文主要向大家介绍了C语言编程入门的代码筛选求素数和普通求法,通过具体的代码向大家展示,希望对大家学习C语言编程入门有所帮助。

素数:除了自身之外,无法被其它整数整除的数称之为素数

C代码(普通)

#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#define N 100
 
//普通方法
int main()
{
    int i, j;
    for (i = 2; i < N; i++)
    {
        for (j = 2; j <= sqrt(i); j++)
        {
            if (i%j == 0)
            {
                break;
            }
        }
        if (j > sqrt(i))
        {
            printf("%d\n", i);
        }
    }
    //return 0;
    system("pause");
}</math.h></stdlib.h></stdio.h>

筛选法

#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#define N 100
//筛选求质数
//具体筛法是:先把n个自然数按次序排列起来。
//1不是质数,也不是合数,要划去。
//第二个数2是质数留下来,而把2后面所有能被2整除的数都划去。
//2后面第一个没划去的数是3,把3留下,再把3后面所有能被3整除的数都划去。
//3后面第一个没划去的数是5,把5留下,再把5后面所有能被5整除的数都划去。
//这样一直做下去,就会把不超过N的全部合数都筛掉,留下的就是不超过N的全部质数。
int main()
{
    int num=0;
    int flag[N+1];
    int i, j;
    for (i = 2; i <= N; i++)
    {
        flag[i] = 1;//初始化,表明此时没有数划去
    }
    for (i = 2; i*i <= N; i++)
    {
        if (flag[i] == 1)
        {
            for (j = 2; i*j <= N; j++)
            {
                flag[i*j] = 0;  //把i的倍数划去
            }
        }
    }
    for (i = 0; i <= N; i++)
    {
        if (flag[i] == 1)
        {
            printf("%4d", i);
            num++;
            if (num % 10 == 0)
            {  
                printf("\n");
            }
        }
    }
    printf("\n");
    system("pause");
}</math.h></stdlib.h></stdio.h>

以上就介绍了C/C+的相关知识,希望对C/C+有兴趣的朋友有所帮助。了解更多内容,请关注职坐标编程语言C/C+频道!

本文由 @Vivian 发布于职坐标。未经许可,禁止转载。
喜欢 | 1 不喜欢 | 0
看完这篇文章有何感觉?已经有1人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程