




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、算法与程序框图一、程序框图与算法基本逻辑结构:1.程序框图符号及作用:程序框图又称流程图,是一种用规定的图形、指向线及文字说明来准确、直观地表示算法的图形图形符号名称功能终端框(起止框)表示一个算法的起始和结束,是任何算法程序框图/、可缺少的口输入、输出框表示一个算法输入和输出的信息,可用在算法中任何需要输入、输出的位置处理框(执行框)赋值、计算.算法中处理数据需要的算式、公式等,它们分别与在不同的用以处理数据的处理框内O判断框判断某一条件是否成立,成立时出口处标明“是”或“Y”;不成立时标明“否”或"N'J1流程线连接程序框,表示算法进行的前进方向以及先后顺序O连接点如果一
2、个流程图需要分开来画,要在断开处画上连接点,并标出连接的号码例:解一元二次方程:ax2bxc0(a0)r<301s,,一la.*珞;一*全/,出卬忖/2.画程序框图的规则:为了使大家彼此之间能够读懂各自画出的框图,必须遵守一些共同的规则,下面对一些常用的规则做一简要介绍.(1)实用标准的框图符号.(2)框图一般按从上到下、从左到右的方向画(3)一个完整的程序框图必须有终端框,用于表示程序的开始和结束(4)除判断框外,大多数框图符号只有一个进入点和一个退出点,判断框是具有超过一个退出点的唯一符号,另外,一种判断框是“是”与“不是”两分支的判断,而且有且仅有两个结果;还有一种是多分支判断,有
3、几个不同的结果.(5)在图形符号内用于描述的语言要非常简练清楚3.算法的三种基本逻辑结构:(1)顺序结构顺序结构是最简单的算法结构,语句与语句之间,框与框之间是按从上到下的顺序进行的,它是由步骤n若干个依次执行的处理步骤组成的,它是任何一个算法离不开的基本结构.如图,只有在执行完步步骤n+1骤n后,才能接着执行步骤n+1.二例:.已知梯形的上底、下底和高分别为解:算法如下:S1a5;S2b8;S3h9;S4S(a+b)xh/2;S5输出S流程图如下:5、8、9,写出求梯形的面积的算法,画出流程图(2)条件结构一些简单的算法可以用顺序结构来实现,顺序结构中所表达的逻辑关系是自然串行,线性排列的.
4、但这种结构无法描述逻辑判断,并根据判断结果进行不同的处理的操作,(例如遇到十字路口看信号灯过马路的问题)因此,需要另一种逻辑结构来处理这类问题条件结构的结构形式如图,在此结构中含有一个判断框,算法执行到此判断框给定的条件P时,根据条件P是否成立,选择不同的执行框(步骤A,步骤B),无论条件P是否成立,只能执行步骤A或步骤B步骤A步骤B步骤A之一,不可以两者都执行或都不执行.步骤A和步骤B中可以有一个是空的.例:某铁路客运部门规定甲、乙两地之间旅客托运行李的费用为0.53,c50 0.53 (50) 0.85,50,其中50,(单位:kg)为行李的重量.试给出计算费用c(单位:元)的一个算法,并
5、画出流程图.S1输入行李的重量;S2如果50,那么c0.53,否贝Uc500.53(50)0.85;S3输出行李的重量和运费c.(3)循环结构在一些算法中要求重复执行同一操作的结构称为循环结构.即从算法某处开始,按照一定条件重复执行某一处理过程.重复执行的处理步骤称为循环体.例:北京成功举办了2008年第29届奥运会.你知道在申奥的最后阶段,国际奥委会是如何通过投票决定主办权归属的吗?对筛选出的5个申办城市进行表决的操作程序是:首先进行第一轮投票,如果有一个城市得票超过总票数的一半,那么该城市就获得举办权;如果所有申办城市得票数都不超过总票数的一半,则将得票数最少的城市淘汰,然后重复上述过程,
6、直到选出一个申办城市为止.怎样用算法结构表述上面的操作过程?解:算法为:S1S2S3投票;统计票数,如果有一个城市得 票超过总票数的一半,那么该城 市就获得举办权,转 S3,否则淘 汰得票数最少的城市,转 S1 ; 宣布主办城市./ fl及市输出遭城市生中的城,这里,“投票”就是一个循环体循环结构有两种形式:直到型循环结构(、结单until型)和当型循环结构(while型)(1)直到型循环结构如图,直到型循环在执行一次循环体 如果条件P不成立则返回继续执行循环体 依次重复操作,直到某一次给定的判断条件 环体A,离开循环结构,继续执行下面的结构A之后,对控制循环的条件 P进行判断,A,执行后,再
7、判断条件 P是否成立,P成立为止.此时,不再返回来执行循.直到型循环,因其先执行一次循环j F循环体A体,再对控制循环的条件进行判断,然后根据判断的结果决定是否继续执行循环 体.当条件不成立时继续执行循环体,当条件成立时,跳出循环结构,所以, 我们也把直到型循环称为“后测试型”循环.是满足条件?(2)当型循环结构如图,每次执行循环体 A前,先对控制循环的条件 P进行判断,当条件 P成 立时执行循环体 A,循环体A执行完毕后,返回来再判断条件P是否成立,如果条件P仍然成立,那么再执行循环体 A,如此反复执行循环体 A,直到某一次返回 来判断条件P不成立时为止,此时不再执行循环体A,离开循环结构,
8、继续执行下面的结构.也正因为当型循环结构先对条件P进行判断,当条件P成立时,执行循环体;当条件不成立时,跳出循环结构,我们常常把当型循环结构还称为“前 测试型”循环.区别:“当型循环”结构中的循环条件时维持循环的;“直到型循环”结构中的循环条件时终止循环的.联系:两个循环形式不同但功能和作用相同,一般情况下可以相互转化100例:写出计算i的算法及程序框图(分别用直到型循环和当i1型循环)(全解P15)解:第一步:设i的值为1;第二步:设sum的值为0;第三步:如果iw100执行第四步,否则转去执行第七步;第四步:计算sum+i并将结果代替sum;第五步:计算i+1并将结果代替i;第六步:转去执
9、行第三步;第七步:输出sum的值并结束算法.循环结构的应用:(1) 确定循环变量和初始条件;(2) 确定算法中反复执行的部分,即循环体;(3) 确定循环的条件;(4) 注意不要出现“死循环”.二、基本算法语句1、输入语句INPUT*提示丙国变量2、输出语句PRINT,提和喀7超武3、赋值语句4、条件语句IF-THEN-ELSE 格式IF-THEN 格式变鎏维达式讦条件THEN语旬IELSE语句2FWFIF条件THEN语句EHDF5、循环语句WHILE语句(2)UNTIL语句三、算法案例1 .任何一种程序设计语言都包含五种基本的算法语句,它们是输入语句,输出语句,赋值语句,条件语句,循环语句2
10、.输入语句的一般格式是INPUT"提示内容"变量;输出语句的一般格式是PRINT"提示内容"表达式;IF 条件 THEN语句体1ELSE语句体2END IFWHILE 条件循环体 .WEND赋值语句的一般格式是变量表达式;IF条件THEN条件语句的一般格式是语句体或ENDIFDO循环语句的一般格式是循环体和LOOPUNTIL条件输入语句、输出语句、赋值语句基本对应于程序框图中的顺序结构;条件语句、循环语句分别用来表达程序框图中的条件结构和循环结构.3 .常用符号运算符号:加_+_,减-_,乘二,除/_,乘方a'b,整数取商求余数MOD.逻辑符号:
11、且AND或OR大于乙等于三,小于<,大于等于>=,小于等于<=,不等于<>.常用函数:绝对值ABS平方根SQR取整INT.4 .算法案例(1)辗转相除法和更相减损术辗转相除法和更相减损术都是求两个正整数的最大公约数的方法.(1)辗转相除法就是对于给定的两个正整数,用大数除以小数.若余数不为0,则将小数和余数构成新的一对数,继续上面的除法,反复执行此步骤,直到大数被小数除尽,则这时较小的数就是原来两个数的最大公约数.(2)更相减损术就是对于给定的两个正整数,若它们都是偶数,则将它们反复除以2(假设进行了k次),直到它们至少有一个不是偶数后,将大数减小数,然后将差和较
12、小的数构成一对新数,继续上面的减法,反复执行此步骤,直到差和较小的数相等,此时相等的数再乘以原来约简的2k即为所求两数的最大公约数(2)秦九韶算法秦九韶算法是求多项式值的优秀算法.设f(x)anxnan1xn1La1xa0,改写为如下形式:f(x)(L(anxani)xan2)xLa1)xa°.设Voan,viVoxan1V2Vixan2V3v?xan3LVnvnixao这样求n次多项式f(x)的值就转化为求n个一次多项式的值.当多项式中有些项不存在时,可将这几项看做0xn,补齐后再利用秦九音S算法进行计算.对于一个n次多项式,只需做n次乘法和n次加法运算即可.(3)进位制K进制数的
13、基数为k,k进制数是由0k1之间的数字构成的.将十进制的数转化为k进制数的方法是除k取余法.把k进制数ananiLaao(Oank,0ani,La,aok)化为十进制数的方法为ananiLa1ao(k)anknankn1Lqka0.一、典例精析11111例1.与出用俯环语句描述求S1L-的值的算法程序.23499100m吨收取的污水例2、某市对排污水进行综合治理,征收污水处理费,系统对各厂一个月内排出的污水量处理费y元,运行程序如下所示:INPUT请写出y与m的函数关系,并求排放污水150吨的污水处理费用IFm50THENy13mELSEIFm100THENy5015*(m50)ELSEy15
14、025(m100)ENDIFENDIFEND求三个数72,120,168的最大公约数变式解:例4.:试写出求正整数m,n(mn)的最小公倍数的算法程序用秦九韶算法求多项式f(x)x52x43x34x25x6在x2时的值.例5.完成下列进制的转化10202(3)(10)(2)101(i0).(8)变式训练:下面是把二进制数11111(2)化为十进制数的一个程序框图,判断框内应填入的条件是()A.i5?B.i4?C.i4?D.i5?二、习题精练(一)基本概念1 .下列关于算法的说法正确的是(A.某算法可以无止境地运算下去8. 一个问题的算法步骤可以是可逆的C.完成一件事情的算法有且只有一种D.设计
15、算法要本着简单、方便、可操作的原则2 .任何一个算法都离不开的基本结构为()A.逻辑结构C.循环结构B.选择结构D.顺序结构3 .下列图形符号表示判断框的是4.能够使算法的程序和步骤表达更为直观的是(A.自然语言 B.流程图C.数学语言D.逻辑语言5 .下面的四种叙述不能称为算法的是()A.广播的广播操图解B.歌曲的歌谱C.做饭用米D.做米饭需要刷锅、淘米、添水、加热这些步骤6 .在流程图中,算法要处理数据或计算,可分别写在不同的()A.处理框内B.判断框内C.输入、输出框内D.循环框内(二)顺序结构及其应用1.早上从起床到出门需要洗脸刷牙(5min)、刷水壶(2min)、烧水(8min)、泡
16、面(3min)、吃饭(10min)、听广播(8min)几个步骤.从下列选项中选最好的一种算法()A.S1洗脸刷牙、S2刷水壶、S3烧水、S4泡面、S5吃饭、S6听广播B.S1刷水壶、S2烧水同时洗脸刷牙、S3泡面、S4吃饭、S5听广播C.S1刷水壶、S2烧水同时洗脸刷牙、S3泡面、S4吃饭同时听广播D.S1吃饭同时听广播、S2泡面、S3烧水同时洗脸刷牙、S4刷水壶2.写出求方程axb0,(a0)的算法步骤G,S2,S33 .将两个数 a=8,b=17交换,使a=17,b=8, A.卜面语句正确一组是a=bb=ab=aa=b(4 .右边流程图表示算法,输出的开始5.“鸡兔同笼”是我国隋朝时期的数
17、学著作孙子算经中的一个有趣而导有深沅影响的题目“今有雉兔同笼,上有三十五头,下有九十四足用方程组的思想不难解决这一问题,请你设计一个这类问题的通用算法(三)条件结构及其应用1.给出以下四个问题,输入一个数x,输出它的相反数.求面积为6的正方形的周长.求三个数a,b,cxX1.0中的最大数.求函数f(X)x2.x0的函数值.其中不需要用条件语句来描述其算法的有()A.1个B.2个C.3个D.4个2 .图中所示的算法的功能是(求两个数中的最大数)开始tmax=a输入b3 .根据题意,完成流程图填空:输入两个数,输出这两个数差的绝对值(结果D. 7该程序运行后输出的k的三、课后作业1 .(2009浙
18、江卷理)某程序框图如图所示,值是()A.4B.5C.6(第一题)2、(2009辽宁卷文)某店一个月的收入和支出总共记录了数,支出记为负数。该店用右边的程序框图计算月总收入理框中,应分别填入()下列四个选项中的A.A>0,V=STB. A<0,V=S-TC. A>0,V=S+TD.AV0,V=S+T3、(2009天津卷理)阅读上(右)图的程序框图,则输出的A26B35C40D57(第二题)N个数据a1,a2,。aN,其中收入记为正S和月净盈利V,那么在图中空白的判断框和处4、(2009年广东卷文)某篮球队6球个数如下表所示:队员i6S=()三分球个数aia2a3a4a5a6下图(右)是统计该6名队员在最近三场比赛中投进的三分球总数的程序框图,则图中判断框应填,输出的s=(注:框图中的赋值符号“=”也可以写成“一”或“:=”)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 无色素性黑色素瘤护理查房
- 安顺市2024-2025学年七年级下学期语文期末模拟试卷
- 阿拉善盟2024-2025学年八年级上学期语文期中模拟试卷
- 安徽省滁州市来安县2024-2025学年高三上学期期末考试化学试卷及答案
- 湖南省常德市桃源县凌津滩乡中学2025年上学期七年级《生物体的结构层次》测试(无答案)
- 心理健康家长讲堂携手共育成就孩子未来模板
- 社区消防知识培训课件活动
- 社区消防知识培训课件会
- 2024-2025学年江西省部分学校九年级(下)月考物理试卷(3月份)-自定义类型(含答案)
- 午餐外卖合同范本
- 2024年全国工会财务知识大赛备赛试题库500(含答案)
- 神的《全备之救》
- GA 38-2021银行安全防范要求
- 第一章数字印刷概述课件
- 【医院管理】-科研创新助推学科建设课件
- 《卷烟原料配方设计》配套教学课件
- 《新能源汽车驱动电机系统检测与维修习题册》 习题参考答案(劳动)
- 介入诊疗质量安全计划与指标
- 新课标高考英语词汇表3500
- 99S203 消防水泵接合器安装图集
- 工资现金发放证明书
评论
0/150
提交评论