欢迎来到天天文库
浏览记录
ID:5526338
大小:305.00 KB
页数:26页
时间:2017-11-15
《3循环结构(嵌套与枚举法解析法递推法)》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、循环结构中的嵌套【例1】输入某次考试成绩mark,统计100分人数good。(输入-1表示结束)分析问题:使用标志法:结束标志为mark=-1;所以在循环前先输入分数mark。循环体:条件mark=100成立,人数good计数,因此要用单分支结构描述,判断结束,再输入下一个分数mark。循环条件:mark〈〉-1说明:循环体可以是顺序的,但也可以是分支的(嵌套分支),同时也能是循环的(嵌套循环),即若循环体本身是循环就称为循环的嵌套。设计算法:先用自然语言描述,再画出流程图,注意:检查流程图的规范性。编写程序:(略)运行程序:上机调试与维护(略)例
2、举检验【例3】实际应用:最值问题输入20个数,求其中最大值max和最小值min。打擂台法【练2】输入n个数,统计正数的个数nz和非正数的个数nfz。(n的值由键盘输入)分析问题:结束条件是什么?首先判断结束循环使用计数法还是标志法。设计算法:请画出流程图。循环体内嵌套什么结构?编写程序:(略)运行程序:上机调试与维护(略)例举检验【例4】求1-1000中,能被3整除的数。【例5】找出1-1000中所有能被7和11整除的数。例举检验基本算法一:枚举法基本算法二:解析法基本算法三:递推法如循环结构中的嵌套满足下列概念则称为枚举法根据所需解决问题的条件,
3、把该问题所有可能的解,一一列举出来,并逐个检验出问题真正解的方法。枚举法也称为穷举法。枚:一个一个举:例举在列举出所有可能的解时,既不能遗漏也不应重复。枚举算法的关键步骤及注意点:列举,用循环结构来实现,要注意循环变量、初值、终值和递增值的设置。检验是否符合问题的要求,用分支结构实现,不同检验结果不同处理方法。注意点:循环变量与判断对象是否是同一个变量;一般情况下没有输入;输出经常是在判断的一个分支中实现的。有些复杂问题一时无法直接找到求解公式或数学模型,则用枚举法体现其优势,非常高的准确性和全面性.但也有缺点:效率不高,是以消耗时间为代价的.枚举
4、法的结构特征:列举检验基本算法一:枚举法【例6】若一个三位数x=100a+10b+c(a、b、c都是个位数),满足a3+b3+c3=x,则x称为水仙花数。找出所有的水仙花数。例举检验【例7】一张单据上有一个5位数的编号,万位数是1,千位数是4,百位数是7,个位数是8,十位数已经模糊不清,只知道该5位数是57或67的倍数,找出所有满足这些条件的5位数并输出。例举检验【例8】百鸡百钱问题:公鸡每只5元,母鸡每只3元,小鸡1元3只,现在用100元钱买100只鸡,求公鸡、母鸡、小鸡各买几只?(提示:是利用枚举法解决实际问题的例子。本例出现了双重循环,即循环
5、嵌套,同时体现了计算机解决问题方法与数学方法的区别)例举检验解析法:根据题目中给出的已知条件,找出已知条件与结果之间关系的数学表达式,并通过表达式的计算来实现问题求解的方法。解析算法的关键:寻找正确的数学表达式解析算法的结构特征:没有特定!可能是顺序结构,也可能是分支或循环结构,甚至是几种结构的组合,完全取决于问题本身.基本算法二:解析法【例1】输入直角三角形的两个直角边的边长值a和b,计算出斜边的边长值c。【例2】输入三角形边长a,b,c,求三角形面积s。【例3】求两个并联电阻的值,公式为:【例4】一元二次方程ax2+bx+c=0(a≠0)的系数
6、a、b、c,求方程的解。递推法:从已知的初始条件出发,依据某种递推关系,逐次推出所要求的各中间结果及最后结果的算法。初始条件一般是问题本身已经给定,或者是通过对问题的分析与化简后确定的。基本算法三:递推法【例1】求斐波那契(Fibonacci)数列的第n个数据项,n由键盘输入。可以用兔子繁殖的实例来说明斐波那契数列:假设兔子出生后两个月就能每月生一对小兔子,如果1月份出生了一对小兔子,那么每个月兔子数就是一个斐波那契数列月份兔子数说明1121321月份的兔子生了小兔子432月份的兔子生了小兔子553月份的兔子生了小兔子684月份的兔子生了小兔子71
7、35月份的兔子生了小兔子8216月份的兔子生了小兔子9347月份的兔子生了小兔子10558月份的兔子生了小兔子11899月份的兔子生了小兔子1214410月份的兔子生了小兔子月份兔子数说明1121321月份的兔子生了小兔子432月份的兔子生了小兔子553月份的兔子生了小兔子684月份的兔子生了小兔子7135月份的兔子生了小兔子8216月份的兔子生了小兔子9347月份的兔子生了小兔子10558月份的兔子生了小兔子11899月份的兔子生了小兔子1214410月份的兔子生了小兔子规律:每个月的兔子数等于上个月的兔子数加上两个月前的兔子数。规律的数学表达:
8、Fn=Fn-1+Fn-2(该数列的各项间的关系,用Fn表示斐波那契数列的第n项)但这里,n≥3,F1=1,F2=1。Fn=
此文档下载收益归作者所有