计算1000以内的总质数个数

#include <stdio.h>

int main() {

  int micro[500];       // 质数保存素组
  int number = 0;       // 质数个数
  
  micro[number++] = 2;  // micro[0]=2
  micro[number++] = 3;  // micro[1]=3, number=2

  unsigned long counter = 0;  // 计算处理次数

  int start = 5;    // 质数开始数字
  int end = 1000;   // 指数结束数字

  int inner ;   // 内层循环变量

  for (start=5; start <= end; start+=2) {
    int flag = 0; // 判断是否为不是指数
    
    // test
    //printf("%d\n", start);

    /*  
     *
     * 循环已经保存的指数为判断条件
     * 例如:100以内人数字
     * 20 * 5 = 100
     * 不被5整除的数字,20也不会被整除
     * */
    for(inner=1; counter++, micro[inner] * micro[inner] <= start; inner++) {
      counter++;

      // printf("%d\n", start);
      // return 0;
if (start % micro[inner] == 0) {
        flag = 1;
        break;
      }   
    }

    if (!flag)
      micro[number++] = start;
  }

  int j = 0;
  for(inner=0; inner < number; inner++) {
    j++;
    printf("%3d\t", micro[inner]);
    if (j % 7 == 0) {
      puts("");
      j = 0;
    }
  }

  printf("处理运算的次数:%lu\n", counter);
  printf("0~%d之间的共个数为:%d\n", end, number);

  return 0;
}
 2      3   5   7  11  13  17 
 19  23  29  31  37  41  43 
 47  53  59  61  67  71  73 
 79  83  89  97 101 103 107 
109 113 127 131 137 139 149 
151 157 163 167 173 179 181 
191 193 197 199 211 223 227 
229 233 239 241 251 257 263 
269 271 277 281 283 293 307 
311 313 317 331 337 347 349 
353 359 367 373 379 383 389 
397 401 409 419 421 431 433 
439 443 449 457 461 463 467 
479 487 491 499 503 509 521 
523 541 547 557 563 569 571 
577 587 593 599 601 607 613 
617 619 631 641 643 647 653 
659 661 673 677 683 691 701 
709 719 727 733 739 743 751 
757 761 769 773 787 797 809 
811 821 823 827 829 839 853 
857 859 863 877 881 883 887 
907 911 919 929 937 941 947 
953 967 971 977 983 991 997 
处理运算的次数:3774
0~1000之间的共个数为:168

原创文章,作者:rainbow,如若转载,请注明出处:http://www.178linux.com/71567

(0)
rainbowrainbow
上一篇 2017-03-22 11:54
下一篇 2017-03-22 22:59

相关推荐

  • 控制字体颜色的输出echo[转载]

    http://onlyzq.blog.51cto.com/1228/546459 echo显示带颜色,需要使用参数-e格式如下:echo -e "\033[字背景颜色;文字颜色m字符串\033[0m"例如: echo -e "\033[41;37m TonyZhang \033[0m"其中41的位置…

    Linux干货 2017-02-01
  • 条件判断(if,case)和循环(for,until,while等)详解(附例题正解)

    脚本中的if条件判断和循环 在linux下,写脚本是我们必不可少的。在写脚本的过程中,if判断和各种的循环是我们常用的。这里,详细的说一下条件判断以及循环的使用。 条件判断:if 和 else 1.if shell程序中的条件分支是通过if条件语句来实现的,其格式一般为if -then -fi ,这样的是单分支语句,还有的一种就是if-then-else-f…

    Linux干货 2016-08-18
  • LVS调度方法

    lvs scheduler:     根据其调度时是否考虑后端主机的当前负载,可分为静态方法和动态方法     静态方法:仅根据算法本身进行调度:         RR:Round Ronin 轮询         WRR:Weighted…

    Linux干货 2017-01-10
  • Linux 进程及作业管理

    Linux 进程及作业管理 概述:      我们在实际的运维工作中经常要对服务器做各种监控,以了解其相关状态,比如,CPU利用率,磁盘空间利用率,等等,这就需要我们了解相关的数据并学会使用各种工具来分析数据。本章就将总结Linux系统中进程管理和作业管理的相关命令、参数和工具,包括:进程的相关定义、分类、状态以及进程查看和管理…

    Linux干货 2016-09-10
  • 马哥教育网络19期+第十二周课程练习

    1、请描述一次完整的http请求处理过程; a.向根域名服务器请求解析域名,然后根服务器返回相应的IP信息; b.用户的Web浏览器向服务器端的80端口通过三次握手建立TCP连接; c.建立完TCP连接后发送HTTP请求,请求的格式包括请求方法、URL和协议版本号,方法有GET、HEAD、POST、PUT、DELETE、OPTIONS、TRACE,如: &n…

    Linux干货 2016-08-22
  • Linux文件查找的使用方法

    文件查找的方法 locate命令       非实时查找(数据库查找): locate查询系统上预建的文件索引数据库 /var/lib/mlocate/mlocate.db    依赖于事先构建的索引;索引的构建是在系统较为空闲时自动进行(周期性任务);管理员手动更新数据库(updated…

    Linux干货 2016-08-15

评论列表(1条)

  • 马哥教育
    马哥教育 2017-03-29 17:18

    不错哦,C也用的这么溜了。