C语言求质数

试编写一个程序,找出2->N之间的所有质数。希望用尽可能快的方法实现。【问题分析】:    这个问题可以有两种解法:一种是用“筛子法”,另一种是从2->N检查,找出质数。    先来简单介绍一下“筛法”,求2~20的质数,它的做法是先把2~20这些数一字排开:    2?3?4?5?6?7?8?9?10?11?12?13?14?15?16?17?18?19?20    先取出数组中最小的数,是2,则判断2是质数,把后面2的倍数全部删掉。    2?|?3 5?7?9?11?13?15?17?19    接下来的最小数是3,取出,再删掉3的倍数    2?3?|?5?7?11?13?17?19    一直这样下去,直到结束。    筛法求质数的问题时,非质数的数据有很多是重复的。例如,如果有一个数3×7×17×23,那么在删除3的倍数时会删到它,删7、17、23时同样也会删到它。有一种“线性筛法”,可以安排删除的次序,使得每一个非质数都只被删除一次。从而提高效率。因为“筛法”不是我要介绍的重点,所以就不介绍了。    现在我来介绍第二种方法。用这种方法,最先想到的就是让从2~N逐一检查。如果是就显示出来,如果不是,就检查下一个。这是正确的做法,但效率却不高。当然,2是质数,那么2的倍数就不是质数,如果令i从2到N,就很冤枉地测试了4、6、8……这些数?所以第一点改建就是只测试2与所有的奇数就足够了。同理,3是质数,但6、9、12……这些3的倍数却不是,因此,如果能够把2与3的倍数跳过去而不测试,任意连续的6个数中,就只会测试2个而已。以6n,6n+1,6n+2,6n+3,6n+4,6n+5为例,6n,6n+2,6n+4是偶数,又6n+3是3的倍数,所以如果2与3的倍数都不理会,只要测试的数就只留下6n+1和6n+5而已了,因而工作量只是前面想法的2/6=1/3,应该用这个方法编程。    还有个问题,就是如果判断一个数i是否为素数。按素数的定义,也就是只有1与本身可以整除,所以可以用2~i-1去除i,如果都除不尽,i就是素数。观点对,但却与上一点一样的笨拙。当i>2时,有哪一个数可以被i-1除尽的?没有,为什么?如果i不是质数,那么i=a×b,此地a与b既不是i又不是1;正因为a>1,a至少为2,因此b最多也是i/2而已,去除i的数用不着是2~i-1,而用2~i/2就可以了。不但如此,因为i=a×b,a与b不能大于sqrt(i),为什么呢?如果a>sqrt(i),b>sqrt(i),于是a×b>sqrt(i)*sqrt(i)=i,因此就都不能整除i了。如果i不是质数,它的因子最大就是sqrt(i);换言之,用2~sqrt(i)去检验就行了。    但是,用2~sqrt(i)去检验也是浪费。就像前面一样,2除不尽,2的倍数也除不尽;同理,3除不尽,3的倍数也除不尽……最理想的方法就是用质数去除i。    但问题是这些素数从何而来?这比较简单,可以准备一个数组prime[],用来存放找到的素数,一开始它里面有2、3、5。检查的时候,就用prime[]中小于sqrt(i)的数去除i即可,如果都除不尽,i就是素数,把它放如prime[]中,因此prime[]中的素数会越来越多,直到满足个数为止!    不妨用这段说明来编写这个程序,但是程序设计的时候会有两个小问题:    1.如果只检查6n+1和6n+5?不难发现,它们的距离是4、2、4、2……所以,可以先定义一个变量gab=4,然后gab=6-gab;    2.比较是不能用sqrt(i),因为它不精确。举个例子,i=121,在数学上,sqrt(i)自然是11,但计算机里的结果可能是10.9999999,于是去除的数就是2、3、5、7,而不含11,因此121就变成质数了。解决这个问题的方法很简单,不要用开方,用平方即可。例如,如果p*p<=i,则就用p去除i。而且它的效率比开方高。【程序清单】:#include?int?creat_prime(int?prime[],int?n,int?total){        i;        j;        gab=2;        count;    for(i=7;i<=n;i+=gab)    {        count=1;        gab=6-gab;        for(j=0;prime[j]*prime[j]<=i;j++)        {            if(i%prime[j]==0)            {                count=0;                break;

c语言求13为质数的代码,C语言求质数.doc相关推荐

  1. c语言写的黑白棋游戏代码,C语言编写的黑白棋游戏源代码..doc

    C语言编写的黑白棋游戏源代码. C语言编写的黑白棋游戏/*3.3.4 源程序*/ #include "graphics.h" /*图形系统头文件*/ #define LEFT 0x ...

  2. 遗传算法(求函数极值)简易代码C语言200行

    思路: //目标函数:y=(x1-1)^2+(x2-2)^2; #include<stdio.h> #include<time.h> #include<windows.h ...

  3. c语言分隔符的作用,句子分割代码(C语言程序的语句分隔符是)

    C#代码中sql 语句段分割 sql server 查询分析器能分析到底当前语句是否结束 可能中间有多个回车. 涉及程序设计 语义的解释.这个很麻烦, 我记得 看过一篇解析语法的程序设计,很麻烦.还是 ...

  4. 用c语言编程最简单的烟花代码,C语言实现放烟花的程序

    这是一个利用C语言编写放烟花的程序(同时也可以播放音乐),供大家参考,具体内容如下 代码如下 #pragma once #include #include //图形界面库头文件 #include // ...

  5. 四阶幻方c语言编程,13年 第四届 蓝桥杯C语言C组 第4题 幻方填空

    标题: 幻方填空 幻方是把一些数字填写在方阵中,使得行.列.两条对角线的数字之和都相等. 欧洲最著名的幻方是德国数学家.画家迪勒创作的版画<忧郁>中给出的一个4阶幻方. 他把1,2,3,. ...

  6. c语言选择排序详解及代码,C语言选择排序算法及实例代码

    选择排序是排序算法的一种,这里以从小到大排序为例进行讲解. 基本思想及举例说明 选择排序(从小到大)的基本思想是,首先,选出最小的数,放在第一个位置:然后,选出第二小的数,放在第二个位置:以此类推,直 ...

  7. c语言打印空心矩形图案的程序,C语言之输出空心棱形图案

    #include #include void main() { int n,j,i; /*i为行数,j为每行中的项数*/ printf("输入图案上三角的高度n:"); scanf ...

  8. python求素数代码_Python编程求质数实例代码

    本文研究的主要是Python编程求质数实例,选取了几个数进行了测试,具体如下. 定义:质数又称素数.一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数:否则称为合数. 我们知道自然 ...

  9. 编程笔试(解析及代码实现):求出一个整数中各位数上所包含全部质数之和

    编程笔试(解析及代码实现):求出一个整数中各位数上所包含全部质数之和 目录 题目描述 代码实现 题目描述 求出一个整数中各位数上所包含全部质数之和 一家电子商务公司计划在圣诞节给客户提供特别折扣,他们 ...

最新文章

  1. MySQL两表联查,根据不同条件获得不同数据
  2. QT udp自动获取对方ip和端口号
  3. Every column needs a corresponding expression. No expression found for xxxx
  4. Resco Photo Viewer for WinCE6.0
  5. binaryoperator java_BinaryOperatorT接口的用法示例
  6. Maven内部版本号插件–用法示例
  7. Activity与Fragment的生命周期
  8. 私有链和联盟链的机会与挑战
  9. 职业学校计算机教学总结报告,中职计算机教师教学工作总结(共6篇) .docx
  10. iPhone进入到了恢复模式怎么办?
  11. 千年疑惑:为什么我越累越失眠,越睡越疲惫?
  12. JVM中引用计数法与可达性分析
  13. 解决ChatGPT网络总是掉线问题
  14. [论文阅读] Self-Sustaining Representation Expansion for Non-Exemplar Class-Incremental Learning
  15. 用js做购物界面的常用效果
  16. 快充诱骗芯片电路应用浅谈
  17. Autoit3我们用来干什么?
  18. 关于oracle11g下的demobld.sql
  19. Windows程序内部运行原理
  20. AndroidP/Q/R编译系统

热门文章

  1. java script error_JavasScript 简单错误总结 错误调试
  2. 【量产工具修复】U盘插上没反应,格式化提示有写保护
  3. coreos 安装 mysql_技术|手把手教你在 CoreOS 上构建你的第一个应用
  4. 2018(第二届)全球物联网大会硕果累累 四大利好推动物联网产业爆发
  5. 目前工资最高的几家外包公司汇总!(2023最新版)
  6. cerebro简单的搭建
  7. 让ie浏览器成为支持html5的浏览器的解决方法(使用html5shiv)
  8. 基于DEAP的脑电情绪识别论文源码改进版本(附论文代码,lstm和rnn)
  9. uniapp微信小程序图片上传
  10. 【SSL.1232】雷达覆盖(计算几何)