编写函数int isprime(int n).pptVIP

  1. 1、本文档共24页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编写函数int isprime(int n)

结构化程序设计的基本思想 采用“自顶向下,逐步求精”的程序设计方法:从问题本身开始,经过逐步细化,将解决问题的步骤分解为由基本程序结构模块组成的结构化程序框图。 据此可容易地编写出结构良好、易于调试的程序。 参考§2.5.2 结构化程序设计P36 结构化程序设计由迪克斯特拉(E.W.dijkstra)在1969年提出,是以模块化设计为中心,将待开发的软件系统划分为若干个相互独立的模块,这样使完成每一个模块的工作变得简单而明确,为设计一些较大的软件打下了良好的基础。 模块的独立性还为扩充已有的系统、建立新系统带来了不少的方便,因为我们可以充分利用现有的模块作积木式的扩展。 * 第二讲 模块化设计与循环嵌套 * 主要内容 模块化设计的思想 划分模块的原则 模块化的实现 小结:结构化程序设计方法 is函数介绍 断点调试 * 模块化设计P37 模块化设计的思想实际上是一种“分而治之”的思想,把一个大任务分为若干个子任务,每一个子任务就相对简单了。 在拿到一个程序模块以后,根据程序模块的功能将它划分为若干个子模块,如果这些子模块的规模还嫌大,还再可以进一步划分更小的模块。这个过程采用自顶向下方法来实现。 * 划分子模块的原则 子模块一般不超过50行。 划分子模块时应注意模块的独立性,即:使一个模块完成一项功能,耦合性愈少愈好 * 嵌套结构转化到函数结构示例 哥德巴赫猜想的验证算法 任何1个大于6的偶数均可表示为2个素数之和。 6=3+3,8=3+5,10=3+7,12=5+7…20=3+17... 50=3+47…… 96=7+89,98=19+79,100=3+97(48个) 循环i从6到100 step 2 将 i 表示为两个素数m1和m2之和 循环m1从3 到i/2 step 1 如果 m1是一个素数 则 如果 m2=i-m1 是一个素数 则 i 验证成功 输出,跳出 i=6 m1=3 m2=3 i=8 m1=3 m2=5 i=10 m1=3 m2=7 i=12 m1=3 m2=9 m1=4 m1=5 m2=7 i=14 m1=3 m2=11 i=16 m1=3 m2=13 i=18 m1=3 m2=15 m1=4 m1=5 m2=13 i=98 m1=3 m2=95 m1=4 m1=5 m2=93 m1=6 m1=7 m2=91 m1=8 m1=9 m1=10 m1=11 m2=87 m1=12 m1=13 m2=85 m1=14 m1=15 m1=16 m1=17 m2=81m1=18m1=19 m2=79 * 展开嵌套算法 教学用例\sample02_09.cpp 计数n=0 循环i从6到100 step 2 1. 循环m1从3 到i/2 step 1 (1) p1=sqrt(m1) (2)循环j从2到p1 如果 m1能被j整除则跳出 (3) 如果jp1 (m1是素数) 则 (i) m2=i-m1 (ii) p2=sqrt(m2) (iii)循环j从2到p2 如果 m2能被j整除则跳出 (iiii)如果jp2( m2 是一个素数) 则 i 验证成功 输出,n++,跳出(1.的循环) 2. 如果n%5 为0则换行 判断素数 程序复杂! * 嵌套结构转化到函数结构示例 sample02_10.cpp (1)编写函数int isPrime(int n),功能是检查n是否为素(质)数,是则返回1,不是则返回0。 (2)编写函数 void prnt(int m),功能是将一个偶数m表示为两个素数之和;并调用isprime判断该数是否为素数。 (3)在main函数中输出100以内可表示为两个素数之和的偶数。要求调用函数 prnt(int m)。 * 编写函数int isPrime(int n),功能是检查n是否为质数,是则返回1,不是则返回0。 int isPrime(int n) { int i; for(i=2;i=sqrt(n);i++) if(n%i==0)return 0; return 1; }

您可能关注的文档

文档评论(0)

wangyueyue + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档