信息学奥林匹克竞赛培训教案(校本课程)

上传人:文*** 文档编号:46392932 上传时间:2021-12-13 格式:DOC 页数:16 大小:149KB
返回 下载 相关 举报
信息学奥林匹克竞赛培训教案(校本课程)_第1页
第1页 / 共16页
信息学奥林匹克竞赛培训教案(校本课程)_第2页
第2页 / 共16页
信息学奥林匹克竞赛培训教案(校本课程)_第3页
第3页 / 共16页
点击查看更多>>
资源描述
信息学奥林匹克竞赛培训教案第1章 计算机的发展与应用1.1  计算机发展简史1.1.1  第一台电子计算机的诞生1946年,世界上第一台数字式电子计算机由美国宾夕法尼亚大学的物理学家约翰·莫克利(John Mauchly)和工程师普雷斯伯·埃克特(PresperEckert)领导研制成功,取名为ENIAC(Electronic Numerical Integrator And Calculator)。它可以在1秒进行5000次加减运算,3毫秒便可以进行一次乘法运算,能存储20个字长为10位的十进制数。1.1.2  计算机发展的几个阶段 第一代(19461958)第二代(19581964)第三代(19641975)第四代(1975至今)主要电子器件电子管晶体管中小规模集成电路大规模/超大规模集成电路内存汞延迟线磁芯存储器半导体存储器半导体存储器外存储器穿孔卡片、纸带磁带磁带、磁盘磁盘、光盘等大容量存储器处理速度(指令数/秒)几千条几百万条几千万条数亿条以上第四代计算机以大规模集成电路VLSI为计算机的主要功能部件,用16K、64K或集成度更高的半导体存储器作为主存储器。新机器要继承原有机器指令系统中的全部指令,使得同一系列计算机的指令系统越来越复杂,这些计算机被称为“复杂指令系统计算机”,简称CISC。日趋庞大的指令系统降低了系统性能,而机器中最常常的是一些简单指令,这些指令仅占指令系统中指令总数的20%,1975年提出了精简指令系统,简称RISC。冯·诺依曼型计算机是采用存储程序方式进行工作。研制中的第五代计算机,是一种智能计算机,具有自动识别自然语言、图形、图像有能力,具有理解和推理能力,具有知识获取、知识更新能力。研制朝两个方向努力:创建非冯·诺依曼式语言,LISP、PROLOG、F.P.;创建以人脑神经系统处理信息的原理为基础的非冯·诺依曼式的计算机模型,生物计算机、光子计算机、量子计算机。1.2  计算机对现代社会的影响1.2.1  计算机应用概述1、科学计算:利用计算机解决科学研究和工程技术中所提出的复杂的数学问题。2、数据处理:利用计算机对所获取的信息进行记录、整理、加工、存储和传输等。3、人工智能:利用计算机来模仿人类的智力活动。4、自动控制:利用计算机对动态的过程进行控制、指挥和协调。5、计算机辅助设计和制造:利用计算机来辅助工程师们设计和制造产品。1.2.2  由信息高速公路热引发的全球信息化浪潮在现代,能源、材料与信息是社会发展的三大支柱。以蒸汽机为中心的动力革命,使人类的体力劳动大大得到了解放;以电子信息技术为先导、以计算机和现代通信产业为代表的信息革命使人类的脑力劳动得到解放。社会发展到每一阶段,都需要有相应的基础设施作支持。在农业社会,田地是社会的基础设施;19世纪进行的工业革命时代,很多国家通过建设高速公路和铁路等交通运输方面的基础设施取得了经济飞速发展;而在信息化时代,信息高速公路就自然成为国家重要的基础设施。1993年美国国家信息基础设施计划提出了一个具有大容量、高速度的电子数据传递系统。该系统由通信网络、信息设备、信息资源和信息环境组成。语言是交流的工具,人与人交流要用语言,其它动物之间交流也有特定的动物的语言,人与计算机交流就要用到一些符号,这些符号的集合形成了计算机的语言。计算机语言有一个发展过程,从机器语言开始,然后是汇编语言,现在则使用高级语言.机器语言和汇编语言属于低级语言,计算机容易懂,但人理解起来困难.高级语言人比较容易理解,因此使得计算机得以普及,当然这是指60年代.实际上,随着应用软件的发展,现在人们连语言也不用学了,也可以使用计算机,而且使用的很好.  当然,高级语言,人虽然容易懂,但计算机又不懂,因此需要翻译.所以高级语言都提供了编译系统或解释系统或集成的开发系统,对高级语言进行翻译,使得计算机能够识别并运行程序.高级语言还在发展,比如面向对象的语言,可视化的语言,网络开发语言等.机器语言和汇编语言也可以称为低级语言.不要认为有了高级语言,低级语言就可以不用了.恰恰相反,在有些领域,低级语言更有用武之处,如控制领域,电子信息领域.因为这些领域对语言运行的速度和效率更感兴趣,这正是低级语言的特点.上述语言都称为形式化的语言,与之相对应的是自然语言,也就是人使用的语言.人与计算机之间能否通过自然语言交流呢?这个恐怕很难.因为按照现在计算机的原理,计算机只有执行程序才能够工作,语言就是用于编出程序来,指挥计算机的工作,没有程序,计算机就不能工作.除非在人与计算机交流时,计算机能把人的语言翻译成程序,否则,人与计算机之间永远也不能实现用自然语言进行交流.而目前这是不太可能的.要么就是改变现在计算机的结构,改变现在计算机的运行模式,那样的话,计算机就要真正的实现更新换代了.第1课  认识PASCAL语言请参阅全国信息学奥林匹克联赛培训教程(一)P87第5章  程序设计语言5.1  程序设计语言基础5.1.1  程序设计语言的组成PASCAL语言是一种高级语言。让我们先来看一个PASCAL程序,通过这个程序了解PASCAL的规则。例L1_1    已知半径,求圆周长和面积的程序PROGRAM circle(input,output); (*  第1行:程序首部  *)已知半径求圆周长和面积(*  第2行:注释  *)  CONST(*第3行:常量说明*)PI=3.14159;  VAR(*第5行:变量说明*)r,l,s:real;  BEGIN(*第7行:语句部分*)read(r);  (*第8行:输入语句*)l:=2*PI*r;  (*第9行:赋值语句*)s:=PI*r*r;write(r,l,s);  (*第11行:输出语句*)  END. (*第12行:语句部分以END.结束*)程序的第一行为程序首部,每个PASCAL程序都必须以PROGRAM 开头;circle是本程序的名字,每个程序的名字可以不同;圆括号里的内容称为程序的参数,程序参数指明程序与外部了解的文件名,input是标准输入文件,例如键盘打字机,output是标准输出文件,指屏幕显示器或打印机,为了读入数据和输出结果,必须写上文件参数input和output。从第三行到最后一行为程序的分程序。分程序一般由说明部分和语句部分构成。说明部分可以包括多种类型的说明。此例包括以CONST开始的常量说明和以VAR开始的变量说明,常量说明必须以CONST开始,变量说明必须以VAR开始。语句部分必须以BEGIN开始,以END.结束,特别注意其中的小圆点(.)不可缺少。中间是一些用分号分开的语句。一个PASCAL程序由程序首部和分程序组成,分程序通常由说明部分和语句部分组成(在特殊情况下可以没有说明部分)。 PROGRAM circle(input,output);  CONSTPI=3.14159;  VARr,l,s:real;  BEGINread(r);l:=2*PI*r;s:=PI*r*r;write(r,l,s);  END.上例的第二行,大括号 中的内容,称为注释。被小括号及星号(* *)括起来的内容也是注释。注释除了给人看,以增加程序的可读性外,对编译和运行都不起作用,一个程序可以包含多个出现在不同地方的注释,也可以没有注释。程序的书写格式:1、PROGRAM写在最左边顶格;2、注释的大括号、和CONST、VAR、BEGIN、END等语句上下对齐,且它们比PROGRAM向右移两个字符;3、各个语句和程序语句也是上下对齐,它们比第2点中的各语句又向右移两个字符;4、使用大写字母的语句:PROGRAM、CONST、VAR、BEGIN、END;5、使用大写字母的标识符:常量标识符。例 L0_001  输入三角形底边和高,求该三角形的面积。写出程序。第二课  PASCAL的数据类型、标识符、表达式、语句PASCAL的数据类型数据对于一门程序语言是非常重要的,数据的一个非常重要的特征就是它的类型。PASCAL规定:程序中出现的变量必须先说明才能使用。PASCAL的标准数据类型数据类型类型标识符适用的数据举例实型real有小数表示法和指数表示法(科学表示法)1.25,132.67,0.0025,-1.561.3267e+2(=1.3267×102=132.67)整型integer包括正、负整数和零25,-32,0字符型char单个的字符A,b,C,0,4,+布尔型boolean只有现个值,即true(真)和false(假) 1、实型(real)实型是最常用的数据类型。在PASCAL,实数有两种表示方法:小数表示法和指数表示法(或称科学表示法)。1.25,132.67,0.0025,-1.56,0.0,100.0以科学表示法表示这些数,可以写成1.25e0,1.3267e+2,2.5e-3,-1.56e0,0e0,1e2在科学表示法中,e后的数字代表10的幂。上列各数可以解释成:1.25e0=1.25×100=1.25,1.3267e+2=1.3267×102=132.67,2.5e-3=2.5×10-3=0.0025,-1.56e0=-1.56×100=-1.56,0e0=0×100=0.0,1e2=1×102=100.02、整型(integer)整型数包括正、负整数和零。例如:25,-32,0。在整数中不得包括不数点(.)。3、字符型(char)字符型数是括在两个单引号中的一个字符。例如:A,b,C,0,4,+,*,代表空字符代表字符abc不是字符型数,因为单引号中只能有一个字符。所有字符都有一个序号与之对应。如0对应48,1对应49,A对应65,B对应66。与字符有关的几个函数函数功能举例ord()返回与字符对应的序号ord(A)=65chr()返回与数字对应的字符chr(65)=Apred()返回前一字符pred(B)=Asucc()返回后一字符succ(A)=B用函数可取得对应的序号,用4、布尔型(boolean)布尔类型的值只有两个:false(假)和true(真)。且false的序号为0,true的序号为1。用于布尔量的运算有布尔运算(或称逻辑运算),它们是:AND(与),OR(或),NOT(非),基本运算规则如下:运算结果0 AND 0假 AND 假0false假0 AND 1假 AND 真0false假1 AND 0真 AND 假0false假1 AND 1真 AND 真1true真     0 OR 0假 OR 假0false假0 OR 1假 OR 真1true真1 OR 0真 OR 假1true真1 OR 1真 OR 真1true真     NOT 0NOT 假1true真NOT 1NOT 真0false假例L0-002  写出下列PASCAL语句的执行结果    A0:=(1>5);    A1:=(1<5);    writeln(A0 AND A0);    writeln(A0 AND A1);    writeln(A1 AND A0);    writeln(A1 AND A1);    writeln(A0 or A0);    writeln(A0 or A1);    writeln(A1 or A0);    writeln(A1 or A1);标识符标识符是以字母开头的字母、数字组合,用来表示常量、变量、类型、文件、函数、过程或程序的名字。x,y,max,min,sum,a15,a3b7都是合法的标识符。而5x,x-y,ex10.5都是非法的标识符。标识符的长度一般不要超过8个字符。标识符的选取最好有一定意义,这样便于记忆,也增加了程序的可读性。表达式和运算符运算符+ , - , * , /AND,OR,NOT,表达式就是将数据和运算符结合使用,组成一组有意义的运算式。在PASCAL语言中规定,表达式按下列运算优先规则计算:1、所有括起来的子表达式必须先计算,且子表达式必须从里到外计算;2、在同一子表达式中的运算符按下列次序计算:函数;NOT;AND,*,/,DIV,MOD;OR,+,-;<,<=,=,>,>=,<>3、在同一个子表达式中,同一优先级的运算按从左到右的次序进行。下面是几个PASCAL表达式的例子:例L0_003数学表达式PASCAL表达式b2-4acb*b-4*a*c(a+b)/(c+d)(a+b)/c+da*b/(c*d)或a*b/c/d a2+bx+c   常用的函数词汇功能 abs绝对值 sqr平方 sqrt开方 ord取序号参数为字符型变量,结果为该字符的序号(整型)chr取字符参数为整型变量,结果为以参数为序号的字符pred前导字符 succ后继字符 odd奇函数,判断是否为奇数参数为整型变量,结果为布尔型trunc去掉小数部分,取其整数round四舍五入,取其整数exp以e为底的指数ln以e为底的自然对数 函数的格式例:开方函数, 在PASCAL中可表示为sqrt(2)语句赋值语句(:=)读语句(read,readln)当实型数据和字符型数据一起读入时,要先读字符型数据。例如a、b、c为实型变量,ch1、ch2、ch3为字符型变量,可以写如下语句:read(ch1,ch2,ch3,a,b,c)不能写成:read(a,b,c,ch1,ch2,ch3)写语句(write,writeln)write语句是写语句(或称输出语句)。用于将计算结果通过屏幕或打字机输出给人看。例如:write(sum,ave)将在屏幕或打字机上输出sum和ave的值。它的一般形式是write(<输出表>)其中输出表是一些由逗号分开的输出项。例如:write(x,y,x+y,x*y)若x的值为2,y的值为3(整数类型),则输出结果为:2    3    5    6为了标记输出结果,可输出相应的字符串。例如将上面的语句改为:write(x=,x,y=,y,x+y=,x+y,x*y=,x*y)则输出结果为:x=2  y=3  x+y=5  x*y=6显然,现在的输出结果,较前面清楚。为了将输出结果打印在不同的行上,可以利用writeln语句。它的作用是在印出输出表的最后一个输出项后,结束当前输出行,使得下一个write(或writeln)语句从下一个新行的开头(左端)输出。例如:writeln(x=,x,y=,y);writeln(x+y=,x+y,x*y=,x*y)输出结果为:x=2  y=3x+y=5  x*y=6write语句可以输出实型、整型、字符型、布尔型值,也可以输出字符串。若在write语句中不加场宽说明,则按标准场宽输出。在这里,场宽是指输出值的位数。数据类型场宽实型以科学表示法输出,占16位整型12位字符型1位布尔型输出true或false,分别占5位和4位当输出值不满规定场宽时,左面用空格代替。不同计算机系统的标准场宽规定可能不同。-1.256734121e+02       13257Afalse实型16位整型12位字符型1位布尔型5位例L2_2  已知三角形的两边及夹角,求第三边及面积。       设三角形的两边及夹角分别为a,b,第三边为c,面积为s。则  , 若以角度值输入,在计算sin和cos时应转换为弧度。角度转弧度的公式为:弧度=角度× PROGRAM XT2_2;  CONST    PI=3.14159;  VAR    a,b,alfa,c,s:real;  BEGIN    read(a,b,alfa);    alfa:=alfa*PI/180;    c:=sqrt(a*a+b*b-2*a*b*cos(alfa);    s:=1/2*a*b*sin(alfa);    write(alfa,c,s);  END.例L2_3  输入一个字符,求其序号、前导(即前一字符)、后继(即后一字符)。PROGRAM L2_3;  VAR    ch,pch,sch:char;    num:integer;  BEGIN    writeln;    writeln;    write('Please input a character:');    readln(ch);    write('pch:',pred(ch),',sch:',succ(ch),',num:',ord(ch)  END.例L2_4  输入x,y。若在圆环内,输出true,若在圆环外,;输出false。圆环如图所示。讨论:如图所示,若下式1x2+y24成立则在圆环内,否则在圆环外。设布尔变量bool,当x,y在圆环内时,让它取值为true,否则取值为false。 Xy120  “(x,y)若在圆环内”的表达式:(x2+y212)且(x2+y222)  PROGRAM L2_4;  VAR    x,y:real;    bool:boolean;  BEGIN    writeln;    write('x=?');    readln(x);    write('y=?');    readln(y);    bool:=(x*x+y*y>=1) and (x*x+y*y<=4);    write(bool);  END. 习题XT1_1  判断下列标识符,哪些是合法的?哪些是非法的?x3,3x,a17,p5q,abcd,x2,ex9.5XT1_2  输入三个数,计算并输出它们的平均值以及三个数的乘积,写出程序。XT1_3  已知地球半径为6371km,计算并输出地球的表面积和体积,写出程序。球表面积计算公式s=4R2 ,球体积计算公式 (其中R指球半径)。XT1_4  已知匀加速运动的初速度为10m/s,加速度为2m/s2,求20s以后的速度,20s内走过的路程及平均速度,写出程序。设初速度为v0,加速度为a,时间为t,末速度为vt,路程为s,平均速度为vave,求末速度公式:vt=v0+at,路程的公式: ,平均速度为vave=  XT1_5  读入摄氏温度c,将它转换成华氏温度 输出,写出程序。转换公式: XT2_1  下列数据哪些是整数?哪些是实数?哪些是非法的数?256,2.50,1e+06,2.2e5,e10,-785,e-5,.5,15.,15.0,0.12,0,0.0,25e, XT2_2  确定下列各常数、表达式的类型和值,表达式类型是指表达式值(结果)的类型。A,3,3,true,false,12/3,12 DIV 3,5>3,5<3,105 MOD 10,round(17/3,trunc(17/3),sqrt(ord(2)-ord(0), sqr(ord(2)-ord(0),(5>3) AND (5<3),chr(67)XT2_3  将下列数学表达式表示成PASCAL表达式(1)-(a2+b2)·y4    (2)sin2(x+0.5)+3cos(2x+4)+tan-1x    (3)u0(1+e-0.5t)(4)     (5)     (6) (7)     (8)|3-exln(1+x)|    (9)     (10) XT2_4  写一程序读入三角形的三个边a,b,c,计算并打印三角形的面积S。可利用下列公式计算。XT2_6  输入二次方程的系数a,b,c(输入数据的选取应保证二次方程为实根),计算并输出二次方程的两个实根。二次方程为:ax2+bx+c=0XT2_7  求图形的表面积与体积。其中r,h1,h2的值由键盘读入。,XT2_8  输入三个字符,然后按输入字符次序输出这三个字符,再输出每个字符的序号,最后按与输入字符相反的次序输出这三个字符。XT2_9  由键盘输入两组x,y值,由程序根据它们是否在示意图中的斜线区域内,输出不同的值。若在斜线区域内,输出true,否则输出false。XT2_10  输入一个三位整数,将它们反向输出。例如输入127,输出应为721。 第3课  选择结构程序设计(20071224)请参阅全国信息学奥林匹克联赛培训教程(一)P1015.3.3  选择结构 3.1  引言通常,计算机按在程序中书写的顺序执行语句。然而,在许多情况下,语句执行的顺序依赖于输入数据或中间运算结果。在这种情况下,必须根据某个变量或表达式的值作出判定,以决定执行哪些语句和跳过哪些语句不执行。我们称这种程序结构为选择结构(或称判定结构)。PASCAL中有两个语句可实现选择结构:IF语句(条件语句)和CASE语句(情况语句)3.2  IF语句3.2.1  IF语句的两种形式IF语句又称如果语句(或称条件语句)。它的一般形式是IF (条件)  THEN (语句1)  ELSE (语句2)其中“条件”实际上是一个布尔表达式,它的值可以是真(true)或假(false)。在条件为真时,执行语句1,否则(条件为假)执行语句2。可以利用流程图来描述选择结构。在流程图中用菱形框表示要执行的判定,其余步骤用矩形框表示,箭头表示执行的顺序。例L3_1  火车托运行李,要根据行李的重量按不同标准收费。例如不超过50kg,按每公斤0.35元收费。若超过50kg,则其中50kg按每公斤0.35元收费,其余超过部分按每公斤0.50元收费。现输入托运行李重量,要求计算并输出托运费。解:讨论:设托运行李重量为weight,该问题要求根据weight是否超过50kg,按不同公式计算出托运费。设托运费为pay。weight和pay均为实型。下面给出算法。一级算法1、读入weight的值。2、根据weight的大小选择不同的公式计算pay。3、输出pay。其中第2步需求精。根据题意,可以写出计算pay的公式如下:weight50 weight>50第2步 计算pay2-1  如果weight502-2  则pay=weight×0.352-3  否则pay=50×0.35+(weight-50)×0.5以上求精步骤要求首先判断weight是否小于等于50。如果小于等于50应执行算法步骤2-2,否则应执行算法步骤2-3。即算法步骤2-2和2-3不是同时执行的,需根据情况选择其一执行。    PROGRAM L3_1;  VAR    weight,pay:real;  BEGIN    write('weight=');    readln(weight);    IF weight<=50      THEN pay:=0.35*weight      ELSE pay:=0.35*50+0.5*(weight-50);    writeln('pay=',pay)  END.除了上面给出的IF语句形式外,PASCAL中还有另外一种IF语句形式。即IF (条件)  THEN (语句)在条件为真时,执行THEN后的语句。在条件为假时,不执行THEN后的语句,在两种情况下的后继语句都是IF语句的下一个语句。例L3_2  读入三个数,找出并打印其中的最大数。解:PROGRAM L3_2;  VAR    a,b,c:real;  BEGIN    write('a=?');    read(a);    write('b=?');    read(b);    write('c=?');    read(c);    IF a<b      THEN a:=b;    IF a<c      THEN a:=c;    writeln('ZuiDaShu:',a)  END.3.2.2  复合语句在IF语句中,跟在THEN或ELSE后的语句可能不止一个,这时要用到复合语句的概念。复合语句是一个以BEGIN开始,以END结束的语句。在BEGIN与END之间可以包括若干个语句,每个语句之间以分号分开。一般形式为:BEGIN  (语句1);  (语句2);    (语句n)END一个复合语句从外部看来,相当于一个语句。例L3_3  读两个数,将大数存于x,小数存于y。解:PROGRAM L3_3;  VAR    x,y,temp:real;  BEGIN    write('x=?');    readln(x);    write('y=?');    readln(y);    IF x<y      THEN BEGIN             temp:=x;             x:=y;             y:=temp           END;    writeln('x=',x:8:2,',y=',y:8:2)  END.3.2.3  复合IF语句在IF语句中,THEN或ELSE后的语句本身也可能是IF语句。此时称为IF语句的嵌套(或称为复合IF语句)。例如语句IF(条件1)  THEN(语句1)  ELSE IF(条件2)          THEN(语句2)          ELSE(语句3)就是一个复合IF语句,在它的ELSE后又是一个IF语句。例L3_4  输入某学生成绩,根据成绩的好坏输出相应评语。如果成绩在90分以上,输出评语:优秀(outstanding);如果成绩在60到90之间,输出评语:良好(satisfactory);如果成绩不足60分,输出评语:不及格(unsatisfactory)。有时IF语句可能会有两种不同的理解。例如语句:IF (条件1)  THEN IF (条件2)           THEN (语句1)           ELSE (语句2)我们可以认为ELSE与后一个THEN配对,其流程图如图3_8(1)所示。但是,我们也可以认为ELSE与前一个THEN配对,其流程图如图3_8(2)所示。为了避免产生不同的理解,PASCAL系统规定ELSE总是与同一层前面最靠近它的,还没有ELSE与之配对的THEN配对。因此,上面的语句肯定是按第一种理解,即ELSE与后一个THEN配对。如果要求按第二种理解执行流程图,可以通过在IF语句中加BEGIN、END的办法来实现。写成IF(条件1)THEN BEGIN        IF(条件2)        THEN(语句1)      ENDELSE(语句2)3.3  CASE语句CASE语句是实现选择结构程序设计的另一种语句。它的使用有时比IF语句来得简单、直观。CASE语句(或称情况语句)的一般形式是CASE (表达式) OF  (值表1):(语句1);  (值表2):(语句2);      (值表n):(语句n)END在CASE语句头上的表达式必须是有序类型(整型、字符型、布尔型以及后面要介绍的枚举型、子界型)。值表是一些由逗号分开的常数。表达式所有可能的值必须在值表中出现,且每个值只能出现一次。如果当前表达式的值在某个值表i中出现,则该程序只执行对应该值表i的语句,然后执行整个CASE语句后的下一语句。例L3_5  输入年、月,输出该月有几天。讨论:每年的1、3、5、7、8、10、12月,每月有31天;4、6、9、11月,每月有30天;2月闰年有29天,平年有28天。年号能被4整除,但不能被100整除,或者年号能被400整除的年均是闰年。用year、month、days分别表示年、月、每月天数。它们均为整数。闰年的条件可以写成如下的布尔表达式:(year MOD 4 = 0) AND (year MOD 100 <> 0) OR (year MOD 400 = 0)PROGRAM L3_5;  VAR    year,month,days:integer;  BEGIN    write(year=?);readln(year);    write(month=?);readln(month);CASE month OF  1,3,5,7,8,10,12:days:=31;  4,6,9,11:day:=30;      2:IF(year MOD 4 = 0) AND (year MOD 100 <> 0) OR (year MOD 400 = 0)       THEN days:=29       ELSE days:=28     END;     writeln(year=,year,month=,month,days=days)   END.例L3_6  输入两个运算量及一个运算符,输出运算结果。这相当于计算器计算。讨论:设两个运算量为x和y,一个运算符为oper,运算结果为result。现在假定运算符只可能是+、-、*、/,将oper说明为字符型。x、y和result说明为实型。习题XT3_1  编制程序,根据输入的x值,计算y与z并输出。 PROGRAM XT3_1;  CONST    PI=3.14159;  VAR    x,y,z:real;  BEGIN    write('x=?');    read(x);    IF x<=2.5      THEN y:=x*x+1      ELSE y:=x*x-1;    IF x<0      THEN z:=-PI/2*x+3      ELSE IF x=0             THEN z:=0             ELSE z:=PI/2*x-5;    writeln('x=',x:6:2,', y=',y:6:2,', z=',z:6:2)  END. XT3_2  对一批货物征收税金,价格在1万元以上的货物征税5%,在5000元以上,1万元以下的货物征税3%,在1000元以上,5000元以下的货物征税2%,1000元以下的货物免税。编写一程序,读入货物价格,计算并输出税金。 XT3_3  输入某学生成绩,若成绩在85分以上,输出very good,若成绩在60分到85分之间,输出good,若成绩低于60分,输出no good。XT3_4  输入3个数,将其中最小数输出。XT3_5  输入3个字母,按字母表顺序从小到大输出这3个字母。 提示:PASCAL不能表示复数。若为复根,应分别计算并输出实、虚部,在输出时将+、-与i用字符形式输出。 XT3_7  输入x、y,根据所处象限,用相应公式计算z。XT3_8  输入x、y及象限,计算z。z的计算公式同XT3_7题,要求用CASE语句编程序。XT3_9  输入班号,输入该班学生人数。应用CASE语句编程序。班号919293949596人数303230303225阅读学习全国信息奥林匹克联赛培训教程(一)(信息学奥林匹克科学委员会主编,清华大学出版社)及网上教案,阅读要求见下表:阅读内容页  码要求5.2  Pascal程序的一般结构和输入输出语句全国信息奥林匹克联赛培训教程(一)P94全看5.3.2  顺序结构全国信息奥林匹克联赛培训教程(一)P100全看5.3.2  选择结构全国信息奥林匹克联赛培训教程(一)P101看1、条件选择结构P101至P1045.4.1  运算对象的显式定义全国信息奥林匹克联赛培训教程(一)P116全看5.4.2  表达式全国信息奥林匹克联赛培训教程(一)P120全看5.4.3  Pascal的简单类型全国信息奥林匹克联赛培训教程(一)P121看1、整型;2、布尔类型;4、字符类型;6、实数类型CHH信息学奥赛培训教案(20071127)bbb:/edu.jianlanaaabbb/TuoZhan/NOI/kwtz_NOIP.htm全看阅读后完成下面题目1、Pascal程序可以分为三个部分,请将这三个部分的名称填入下面括号中PROGRAM circle(input,output);  CONSTPI=3.14159;  VARr,l,s:real;  BEGINread(r);l:=2*PI*r;s:=PI*r*r;write(r,l,s);  END.2、完成下面有关数据类型的表数据类型类型标识符举2个例子实型   integer 字符型   boolean 3、请将下列实型数据用另一种表示法表示小数表示法科学表示法小数表示法科学表示法例:12.51.25e+1 1e+2132.67  -3.05e+10.0025  -2.509e-4-1.56  5.201e-25982.37  3.8e+20.84  3.7e-3-0.0071  3.05e04、在Pascal中,有六个算术运算符,它们是_。有六个关系运算符,它们是_。有三个逻辑运算符,它们是_。6、填出下面Pascal词汇所属类别(在“语句、函数、运算符、数据类型、符号”中选择其一)序号词汇类别功能序号词汇类别功能1:=  30sqr 平方2abs 绝对值31sqrt 开方3AND 逻辑运算符“与”32succ 后继字符4BEGIN 分程序开始33THEN 条件语句IFTHENELSE的一部分5boolean  34TO FOR循环语句的一部分6CASE 分支结构语句35trunc 去掉小数部分,取其整数7char  36VAR 说明变量8chr 取字符37WHILE 循环语句WHILE9CONST 定义常量38sin  10DIV 整数商39cos  11DO WHILE DO语句的一部分40arctan  12ELSE 条件语句IFTHENELSE的一部分41+  13END 结束分程序42-  14exp 以e为底的指数43*  15FOR FOR循环语句44/  16GOTO  45<   17IF IF条件语句46<=  18integer  47=  19ln 以e为底的自然对数48>=  20MOD 取余,整除后的余数49>   21NOT 逻辑运算符“非”50<>   22odd 奇函数,判断是否为奇数51write  23OF 分支结构语句CASEOF的一部分52writeln  24OR 逻辑运算符“或”53read  25ord 取序号54readln  26pred 前导字符55:  27PROGRAM 程序首部56'  28real  57;  29round 四舍五入,取其整数    2、在第1题例中,语句write与writeln有何不同_。3、在第1题例中,哪些词属于保留字_。5、将下列代数式写成Pascal的表达式(1)4×(13-4)÷6        (2)a-(m-d)×4÷b+3y=A26、下列符号中,能作标识符的是:AI, Wang, 4D4g, IF, MAX, ABS, PI, SIN, ABS_1, Begin友情提示:部分文档来自网络整理,供您参考!文档可复制、编制,期待您的好评与关注!16 / 16
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 大学资料


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!