- 1、本文档共24页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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; }
您可能关注的文档
- 第12章:域名系统.ppt
- 大学英语四级考试备考策略.ppt
- 推进农村信息化发展的有益实践 - 浙江省科技厅.doc
- 第四章 学前儿童科学教育方法(上).ppt
- 保温材料入场复验项目一览表(2014版) - 无锡市建筑工程质量检测中心.doc
- ny 1429-2010 含氨基酸水溶肥料pdf.pdf
- 计算机网络技术学业测试样题.doc
- 软件和信息服务业动态 - 广东软件行业协会.pdf
- 山东省地方标准山东省物流园区等级划分与评定 - 山东省物流与交通 .pdf
- 班级的教学目标.ppt
- 基于人工智能教育平台的移动应用开发,探讨跨平台兼容性影响因素及优化策略教学研究课题报告.docx
- 高中生物实验:城市热岛效应对城市生态系统服务功能的影响机制教学研究课题报告.docx
- 信息技术行业信息安全法律法规研究及政策建议教学研究课题报告.docx
- 人工智能视角下区域教育评价改革:利益相关者互动与政策支持研究教学研究课题报告.docx
- 6 《垃圾填埋场渗滤液处理与土地资源化利用研究》教学研究课题报告.docx
- 小学音乐与美术教师跨学科协作模式构建:人工智能技术助力教学创新教学研究课题报告.docx
- 《航空航天3D打印技术对航空器装配工艺的创新与效率提升》教学研究课题报告.docx
- 教育扶贫精准化策略研究:人工智能技术在区域教育中的应用与创新教学研究课题报告.docx
- 《区块链技术在电子政务电子档案管理中的数据完整性保障与优化》教学研究课题报告.docx
- 《中医护理情志疗法对癌症患者心理状态和生活质量提升的长期追踪研究》教学研究课题报告.docx
文档评论(0)