90基本算法语句

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

算法的基本语句温故而知新1.什么是算法?什么是程序框图?2.算法的基本逻辑结构有哪些?算法通常是指按照一定规则解决某一类问题的明确的和有限的步骤。程序框图是一种用程序框、流程线及文字说明来表示算法的图形。算法的基本结构有三种:顺序结构、条件结构、循环结构,其中循环结构又分为当型结构和直到型结构两种。第一课时算法的基本结构:①顺序结构②条件结构③循环结构顺序结构条件结构循环结构①顺序结构是最基本的结构,是任何结构都需要用到的;②条件结构是我们在解决条件判断问题中,常用到的一种结构,它是计算机基本的逻辑推理结构;③循环结构是解决反复问题的结构。温故而知新计算机完成任何一项任务都需要算法,但当计算机真正运行算法时,计算机是无法“理解”自然语言或程序框图的。还需要将算法用计算能够“理解”的程序设计语(programminglanguage)表示成计算机程序。计算机通过程序设计语言将它们“翻译”成计算机语言计算机语言有很多种,为了实现算法中三种最基本的结构:顺序结构、条件结构和循环结构,个种程序设计语言都要用到下面的最基本的算法语句:输入语句输出语句赋值语句条件语句循环语句我们使用的程序设计语言虽然有很多种,如:BASIC、PASCAL、C、COBOL、FORTRAN、LOGO以及VC、VB语言,但在语句形式以及语法上和BASIC语言类似,稍加改造就可以在计算机上运行BASIC语言全称是Beginner’sallPurposeSymbolicInstructionCode,意为“初学者通用符号指令代码“。1964年由美国达尔摩斯学院的Thomas和JohnG.Kemeny完成设计并提出了BASIC语言的第一个版本,经过不断丰富和发展,现已成为一种功能全面的中小型计算机语言。BASIC易学、易懂、易记、易用,是初学者的入门语言,也可以作为学习其他高级语言的基础。BASIC有解释方式和编译方式两种翻译程序下面我们就这些基本语句来进行一一说明JohnG.KemenyThomas1.输出、输入和赋值语句基本上对应算法中的顺序结构语句n语句n+1利用输入、输出语句可以实现信息的录入和结果的输出1.2.1输入语句输出语句赋值语句输入语句、输出语句分别与程序框图中的输入、输出框对应赋值语句与程序框图中表示赋值的处理框对应,用来给变量赋值算法:第二步:计算的值;3232430yxxx开始输入x3232430yxxx输出y结束框图:例1.用描点法作函数的图象时,需要求出自变量和函数的一组对应值,编写程序,分别计算当x=-5,-4,-3,-2,-1,0,1,2,3,4,5时的函数值。3232430yxxx第一步:输入x的值;第三步:输出y的值。程序:INPUT“x=”;xy=x^3+3x^2-24x+30PRINTyEND**INPUT“x=”;xy=x^3+3*x^2-24*x+20PRINTyEND认识程序:输入语句赋值语句输出语句一、输入语句1、一般格式:INPUT“提示内容”;变量②“提示内容”提示用户输入什么样的信息。可以是中文,也可以是其他的③变量是指程序在运行时其值是可以变化的量。2、说明:①作用为实现算法的输入信息功能。④输入语句要求输入的值只能是具体的常数。⑤提示内容与变量之间用“;”隔开,有多个变量的输入时,变量与变量之间用“,”隔开。INPUT“Maths,Chinese,English”;a,b,c二、输出语句1、一般格式:PRINT“提示内容”;表达式2、说明:①作用是实现算法的输出结果功能。②“提示内容”提示用户输出什么样的信息。③表达式是指程序要输出的数据。④输出语句可以输出常量、变量或表达式的值及字符。INPUT“Maths=”;aINPUT“Chinese=”;bINPUT“English=”;cPRINT“Theaverageis”;(a+b+c)/3三、赋值语句1、一般格式:变量=表达式2、说明:①作用是将表达式所代表的值赋给变量。②赋值语句中的“=”称为赋值号。③赋值语句右边可以是一个数据、常量和算式,左边只能是变量,不能为表达式。④赋值号左右不能对换。除了INPUT语句,例1中也可以用“赋值语句”给变量提供初值INPUT语句PRINT语句赋值语句格式INPUT“提示内容”;变量PRINT“提示内容”;表达式变量=表达式说明1.“提示内容”和它后面的“;”可以省略;2.一个语句可以给多个变量赋值,中间用“,”隔开;3.无计算功能,不能输入表达式;4.输入多个数据时用“,”分隔,且个数要与变量的个数相同。1.“提示内容”和它后面的“;”可以省略;2.一个语句可以输出多个表达式,不同的表达式之间用“,”隔开;3.表达式可以是变量,也可以是计算公式;4.有计算功能,能直接输出计算公式的值。1.“=”左侧必须是变量,右侧可以是数字、变量或者是计算公式;2.一个语句只能有一个“=”,并且只能给一个变量赋值;3.有计算功能,可以把表达式的值赋给一个变量。例2.编写程序,计算一个学生数学、语文、英语三门课的平均成绩。算法:第一步:分别输入三科的成绩a,b,c;第二步:计算average=(a+b+c)/3;第三步:输出三科平均分。框图:开始输入a,b,c输出average结束average=(a+b+c)/3程序:INPUT“Maths=”;aINPUT“Chinese=”;bINPUT“English=”;caverage=(a+b+c)/3PRINT“Theaverage=”;averageENDINPUT“Maths,Chinese,English=”;a,b,c程序2:PRINT“Theaverage=”;(a+b+c)/3END〖例3〗:给一个变量重复赋值。程序:A=10A=A+15PRINTAENDA的输出值是多少?分析:此程序给变量A赋了两次值.A的初值为10,第二次赋值后,初值被“覆盖”,A的值变为25,因此输出值是25.[变式引申]:在此程序的基础上,设计一个程序,要求最后A的输出值是30.A=10A=A+15PRINTAA=A+5PRINTAEND程序:〖例3〗:给一个变量重复赋值。程序:A=10A=A+15PRINTAEND例4、交换两个变量A,B的值INPUTAINPUTBPRINTA,BX=AA=BB=XPRINTA,BEND先将A的值赋予X这时X取A的值再将B的值赋予A这时A取B的值再将X的值赋予B这时B取X的值即A的值先将A的值赋予X这时X取A的值X为中间变量X是什么?数学符号与程序符号的比较功能数学符号程序符号或函数乘法运算符×*除法运算符÷/指数运算axa^x不大于≤=功能数学符号程序符号或函数不小于≥=不等号≠绝对值|x|ABS(x)算术平方根xSQR(x)逻辑“且”运算AND逻辑“或”运算OR取余数MOD〖练习〗:编写一个程序,要求输入一个圆的半径,便能输出该圆的周长和面积.(π取3.14)分析:设圆的半径为R,则圆的周长C=2πR,面积S=πR2,可以利用顺序结构中的INPUT语句,PRINT语句和赋值语句设计程序。INPUT“R=”;RC=2*3.14*RS=3.14*R^2PRINT“C=”;CPRINT“S=”;SEND练习课本P24.1、2、3、4INPUT“a,b,c=”;a,b,cX=10.4*aY=15.6*bZ=25.2*csum=X+Y+ZPRINT“sum=”;sumEND4题答案练习课本P33A2练习《与名师对话》P15.变式训练3《与名师对话》P16成功体验1、2、3、4、5、第二课时条件语句的一般格式①只含一个“分支”的条件结构写成条件语句为IF条件THEN语句体ENDIF当计算机执行这种形式的条件语句时,首先对IF后的条件进行判断,如果条件满足,就执行THEN后的语句体,否则执行ENDIF之后的语句.满足条件?语句体是否1.2.2条件语句IF——THEN——ENDIF型条件语句是处理条件结构的算法语句满足条件?语句体1语句体2是否②含两个“分支”的条件结构写成条件语句为IF条件THEN语句体1ELSE语句体2ENDIF当计算机执行上述语句时,首先对IF后的条件进行判断,如果条件符合,就执行THEN后的语句体1,否则执行ELSE后的语句体2.IF——THEN——ELSE——ENDIF型例5、编写程序,输入一个x的值,要求输出它的绝对值。INPUTxTFx=0THENPRINTxELSEPRINT-xENDIFEND程序框图开始输入x判断x0是输出x否输出-x结束第一步:输入x;第二步:判断x的符号;若x≥0,则输出x,否则输出—X;算法INPUTxIFx0THENx=-xENDIFPRINTxEND例5[变式引申]:编写程序,输入一个x的值,如果它是正数,则输出它,否则不输出。INPUTxIFx0THENPRINTxENDIFEND程序如图所示开始输入x判断x0是输出x否结束框图〖例6〗:编写程序,输入一元二次方程ax2+bx+c=0的系数,输出它的实数根。算法分析:一元二次方程的根有三种不同情况:设判别式△=b2-4ac(1)当△0时,一元二次方程有两个不等的实数根.(2)当△=0时,一元二次方程有两个相等的实数根.122bxxa(3)当△0时,一元二次方程没有实数根.1,2bxa22bxa1,22bxaa222bxaa2bpa2qa用IF—THEN—ELSE—ENDIF结构【程序】INPUT“a,b,c=”;a,b,cd=b*b-4*a*cIFd=0THENp=-b/(2*a)q=SQR(d)/(2*a)IFd=0THENPRINT“Onerealroot:”;pELSEx1=p+qx2=p-qPRINT“Tworealroots:”;x1,x2ENDIFELSEPRINT“Norealroot!”ENDIFEND是开始△=b2-4ac△≥0?2bpa2qa原方程无实根否结束△=0?输出p是否x1=p+qx2=p-q输出x1,x2输入a,b,c外循环内循环〖例7〗:编写程序,使得任意输入的3个整数按从大到小的顺序输出。算法分析:用a,b,c表示输入的3个整数;为了节约变量,把它们重新排列后,仍用a,b,c表示,并使a≥b≥c.具体操作步骤如下。第一步:输入3个整数a,b,c.第二步:将a与b比较,并把小者赋给b,大者赋给a.第三步:将a与c比较.并把小者赋给c,大者赋给a,此时a已是三者中最大的。第四步:将b与c比较,并把小者赋给c,大者赋给b,此时a,b,c已按从大到小的顺序排列好。第五步:按顺序输出a,b,c.c=bb=tb=tc=ta=c【程序框图】开始输入a,b,cba?是t=aa=b否ca?是t=a否cb?t=c是否输出a,b,c交换a,b的值【程序】INPUT“a,b,c=”;a,b,cIFbaTHENt=aa=bb=tENDIFIFcaTHENt=aa=cc=tENDIFIFcbTHENt=bb=cc=tENDIFPRINTa,b,cEND课本P29页1.INPUT“a,b,c=”;a,b,cIFa+bcANDa+cbANDb+caTHENPRINT“Yes.”ELSEPRINT“No.”ENDIFEND参考答案:【课堂练习1】【课堂练习2】课本P29页2.读程序,说明程序的运行过程.INPUT“x=:”;xIF9xANDx100THENa=x\10b=xMOD10x=10*b+aPRINTxENDIFEND如果有两个或是两个以上的并列条件时,用“AND”把它们连接起来。“\”用来取商.此处表示x除以10的商.“MOD”用来取余数.此处表示x除以10所得余数为b.[问题]如输入的数x=86,则输出的结果是什么?68此程序用于交换一个两位数的个位和十位数字.课本P29页3.编写求一个数是偶数还是奇数的程序,从键盘输入一个整数,输出该数的奇偶性.INPUT“a=”;aIFaMOD2=0THENPRINT

1 / 60
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功