高级语言程序设计试卷及答案解析.docx

上传人:h**** 文档编号:1122576 上传时间:2018-12-10 格式:DOCX 页数:81 大小:120KB
下载 相关 举报
高级语言程序设计试卷及答案解析.docx_第1页
第1页 / 共81页
高级语言程序设计试卷及答案解析.docx_第2页
第2页 / 共81页
高级语言程序设计试卷及答案解析.docx_第3页
第3页 / 共81页
高级语言程序设计试卷及答案解析.docx_第4页
第4页 / 共81页
高级语言程序设计试卷及答案解析.docx_第5页
第5页 / 共81页
点击查看更多>>
资源描述

1、 1 / 811.1 单项选择题 1二进制语言是属于( )面向机器语言 面向问题语言 面向过程语言 面向汇编语言【解】人们研制了许许多多计算机程序设计语言,其中二进制语言直接来自计算机的指令系统,与具体计算机紧密相关,所以是一种面向机器语言。面向问题语言是为了易于描述和求解某类特定领域的问题而专门设计的一种非过程语言。面向过程语言是一种能方便描述算法过程的计算机程序设计语言。有汇编语言,但没有面向汇编语言。汇编语言也是一种面向机器的语言,与机器语言比较,汇编语言用有助于记忆的符号来代表二进制代码。所以解答是。 2下列语言中不属于面向过程的语言是( )高级语言 低级语言 C 语言 PASCAL

2、语言【解】 C 语言和 PASCAL 等程序设计语言都是高级语言,它们用于描述复杂加工的处理过程,所以也称它们是面向过程语言。低级语言是指机器语言和汇编语言,低级语言是面向机器的语言,而不是面向问题的语言。所以解答是。 3下列字符中属于键盘符号的是( ) n t b【解】键盘符号是指键盘上有标记,并能在显示器上直接以其标记字样显示的字符。有许多键盘上有标记的符号,它们不是用于直接显示的,键入这种字符用于表示特定的意义,如常用的回车符。为了能让 C 程序标记这种符号,程序采用转义字符的方式书写这种字符。如“n“、“t“ 、“b“都不是键盘字符,在 C 语言中,它们都得用转义字符来表达。只有字符才

3、是键盘字符。所以解答是。但在 C 程序中,反斜杠字符已特别用作转义字符的引导符,它也得用转义字符的表达形式书写,将它写成“。 4下列字符列中,不是用来表达转义字符是( ) “ 074 【解】转义字符有三种书写形式:反斜社字符后接上某个规定的字符;反斜杠字符后接上13 个八进制数字符;反斜社字符和字符 X 之后接上 1 至 2 个十六进制数字符。后两种分别八进制数和十六进制数直接给出字符的 ASCll 代码值。而 074 是八进制整数,不是转义字所以解答是。 2 / 815不是 C 语言提供的合法关键字是()switch begin case default【解】因 C 语言的关键字表中没有 b

4、egin,它不是 C 语言的关键字。所以解答是。 6下列字符列中,能作为单个标识符是()l? a a2 a.3 a_3【解】在 C 语言中,规定标识符是这样一种字符序列,由英文字母或下线字符开始,后接任 1 个英文字母、下线字符和数字符组成。所以问题所列的字符列只有 a3 是标识符,其余都 l 是标识符,一个是由字符“?“开头、一个中间有字符“,另一个有字符“。所以解答是。 7在 C 语言中,下列说法中错误的是()函数定义可以分为两个部分:函数说明部分和函数体主函数可以调用任何非主函数任何非主函数可以调用其它任何非主函数程序可以从任何函数开始执行【解】每个 C 函数的定义分两部分,函数说明部分

5、和函数体,所以叙述 是正确的叙述。C 语言中,函数可以递归调用,主函数可以调用程序中的任何函数,当然可以调用任何非主教的其它函数,所以叙述是一个正确的叙述。同样理由,叙述也是正确的。C 语言规,C 程序只有一个主函数,并总是从主函数开始执行,不能从非主函数开始执行。所以,说程可以从任何函数开始执行是错误的。所以解答是。1.2 填充题1汇编语言属于面向_ 语言,高级语言属于面向_语言。【解】汇编语言与具体计算机密切有关,是属于面向机器的语言;而高级语言用来描述求解题的算法,所以是面向过程的语言。所以解答是:面向机器和面向过程。 2用高级语言编写的程序称为_ 程序,它可以通过 _程序翻译一句执一句

6、的方式执行,也可以通过_ 程序一次翻译产生_程序,然后执行。【解】用高级语言编写的程序称为源程序,源程序不能在计算机上直接运行,运行源程序有种方式:一种是通过解释程序,对源程序逐句解释执行;另一种是先让编译程序将源程3 / 81序一翻译产生目标程序(目标程序是计算机可直接执行的机器语言程序,它是一种二进制代码程),然后执行目标程序。 3转义字符是由_符号开始,后接单个字符或若干字符组成。4C 语言词类主要分为_、_、_和_等。【解】语言的基本词汇是指直接由字符序列组成,有确定意义的最基本单位,所以 C 语言词汇有:字面形式常量。特殊符号(主要是运算符)、保留字和标识符等四类。而表达式、函数调用

7、等是更高级的语言成分,如表达式中还可分运算分量和运算符等;函数调用也是一种表达式,它有函数名标识符、圆括号和实际参数表等。利用基本词汇,按照给定的 C语言的句法规则,就可命名程序对象,描述表达式计算、构造语句、函数,直至整个程序。5C 语言的语句主要分为_语句、_语句、_语句_语句、_ 语句和_语句等。【解】C 语言有多种不同功能的语句,有用于定义数据的,有用于各种存储和计算的,有用于程序流程控制的,有多种分类方法。C 语言的语句主要有:数据定义语句、表达式语句、流程控制语句、复合语句、空语句和其它语句。程序中经常使用的赋值表达式语句和函数调用表达式语句都是典型的表达式语句。 6C 程序是由函

8、数构成的。其中有并且只能有_ 个主函数。 C 语言程序的执行总是由_函数开始,并且在_函数中结束(如别的函数未调用终止程序执行的库函数)【解】C 程序是由若干函数构成的。其中有并且只能有 1 个主函数(用 main 命名)。C 程序的执行总是由主函数开始执行,通常在主函数中结束(如没有在别的函数中调用终止程序执行的库函数的话)。 7C 语言程序的注释可以出现在程序中的任何地方,一个注释以双符号作为开始标记,以双符号_作为结束标记。【解】C 语言程序的注释可以出现在程序基本单词之间的任何地方, C 语言程序的注释以双符号“。非为开始标记,并以双符号“。“作为结束标记。2.1 单项选择题 1下列字

9、符列中,可以作为“字符串常量“的是( ) ABC ABC“ “abc“ “a“ 【解】C 程序中,一个字符率常量是表示一个字符序列,书写时,用双引号字符前后括住这个字符序列。所以只有“ABC“是一个正确的字符率常量,其余都不是。其中,ABC 可作为标识符,字符列“abc“不能出现在 C 程序中,“a“是一个字符常量。所以解答是。 4 / 812在以字节存储字符的系统中,“n “在内存占用的字节数是( )1 2 3 4【解】一般来说,一个字符在内存中只占 1 个字节,“n“是转义字符,其意义是换行符,它作为一个字符存储,在内存也只占五个字节。所以解答是。 3字符串“XyZ“在内存占用的字节数是(

10、 )3 4 6 8【解】字符串中的每个字符占 1 个字节,但 C 程序在存储字符串时,要在最后一个有效字符后面接上 1 个字符串结束的标记符“。这样,存储字符串常量“xyZ“需要 4 个字节。所以解答是。 4在以下字符列中,合法的长整型常数是( ) OL 4962710 0.054838743 2.1869el0【解】为表示不同范围的整数,整型数据分短整型、基本型和长整型,并对三种整型内部表示的最高位的不同理解,又分别分成无符号和带符号两种。若要明确指明一个整数是长整型的,必须在整数之后接上字符“L“。所以 OL 是一个长整型的整型常量,而 4962710 是基本整型数据,而对于用 2 个字节

11、表示一个基本整型数据的系统来说,该整数将因超出范围而是一个错误的整数;0.054839743 和 2.1869el0 都是 double 型的实数。所以解答是。 5一个 char 型数据,它的值在内存中存放的是()ASCll 代码值 BCD 代码值 内码值 十进制代码值【解】计算机存储字符,通常是存储字符的某种代码值。有许多种字符编码的方法,最流行的是 ASCII 代码。在 C 语言中, Char 型数据也用 ASCII 代码表示。所以解答是。 6设变量 m, n,a,b,c,d 均为以执行(ma)|(n cd)后,m,n 的值是( )0,0 0,1 l,0 1,1【解】计算(mab)|(n=

12、c=d)的过程是先计算逻辑或的左运算分量(m=a=b)的值,由于赋位运算符的优先级比关系运算符=的优先级低,又先计算 a=b。因 a,b 均为0 后,所以比较结果值为 1。将 1 赋给变量 m,使变量 m 的值变为 1 。同时这个赋值运算的结果也是 1,这样逻辑运算的左运算分量的值为 1。由于逻辑或运算的左运算分量值为1,按照 C 语言对逻辑或运算优化计算的规定,不再计算逻辑或的右运算分量,而直接得到5 / 81逻辑或运算的结果为 1 。由于逻辑或的右运算分量不曾计算过,所以变量 n 的值也不为变化。这样,上述表达式计算后,变量 m 的情为 1,变量 n 的值为 0。所以解答是。 7设 a 为

13、 5,执行下列计算后,b 的值不为 2 的是( ) ba2 b6-(a) ba2 ba3?3:2【解】因两个整型数据相除,结果是整数,当 a 的值为 5 时,计算表达式 b=a2 后,使 b的值为 2。计算表达式 b6-(-a)是先计算子表达式(-a)的,先让 a 的值减 1 变成 4,并以减1 后的 a 为子表达式的结果,所以子表达式的结果为 4,最后使 b 的值为 2。在计算表达式b= a%2 时,求余运算 a2 的结果为 1,最后使变量 b 的值为 1。计算表达式ba3?3 :2 时,先计算条件表达式 a3?3:2,以 2 为结果,最后也使变量 b 的值为人所以解答是。 8执行语句“x(

14、a3 ,ba );“后,X,a,b 的值依次为( )3,3,2 2 ,3 ,2 3 ,2,3 2,3 ,3【解】计算表达式 x(a=3,b=a-)时,先计算赋值号右端圆括号内的逗号表达式。远号表达式要求各子表达式顺序计算,并以最后予表达式的值为整个逗号表达式的结果。所以该表达式计算时,先让变量 a 的值为 3,a-的值是 a 当时的值,以该值为结果赋给变量 b,并以该值为远号表达式的值赋给变量 x,然后 a 的值被减少 1。所以计算该表达式后,使变量 x,a,b 的值依次为 3,2 ,3。所以解答是。9设整型变量 m,n,a,b, c,d 均为 1,执行“( mab)(nab)“后 m,n 的

15、值是( )0,0 0,l 1,0 1 ,l【解】表达式(ma b)(n a b)是一个逻辑表达式,它的计算过程是先计算逻辑与的左分量(mab,其中又是先计算 ab。因 ab 不成立,结果为 0,将 0 赋给变量 m,最后逻辑与的左分量结果为 0。由于逻辑运算采用特别的优化计算规则,当逻辑与的左分量结果为 0 时,不再计算逻辑与的右分量,而直接以 0 为逻辑与的结果。所以,上述表达式计算使 m 的值变为 0,而 n 的值没有变,依旧为 l。所以解答是。 10,设有代码“int a3 ;“,则执行了语句“a+=a-= a*a;“后,变量 a 的值是( )3 0 9 -12【解】由于赋值运算符的结合

16、性自右至左,语句“a+=a-=a*a;“的执行是先计算 a*a,得到值 9,再计算 aa*a ,使 a 的值为 -6,接着计算 aa,使 a 的值为-12。所以解答是。 6 / 8111在以下一组运算符中,优先级最高的运算符是( ) % 【解】常规运算符的优先级自高到低的排列顺序是算术运算符、移位运算符、关系运算符。按位运算符、逻辑运算符、条件运算符、赋值运算符、逗号运算符。所以问题所给的四个运算符按优先级自高到低的排列顺序是,。所以解答是。 12设整型变量 i 的值为 3,则计算表达式 i-i 后表达式的值为( )0 l 2 表达式出错【解】有些运算符只有一个字符,也有许多运算符由两个字符组

17、成。特别是有些字符既可是单个字符的运算符,又能组成双字符的运算符。编译系统在识别源程序时,通常是尽量多地读八字符,能组成多字符单词的先尽量组成多字符单词。所以表达式 i-i,被编译器理解为(i-)-i。另外,当表达式中某变量有后缀自增和自减运算时,先按变量的原值计算表达式,然后再对变量进行自增和自减运算。同样地,当表达式中某变量有前缀自增和自减运算时,先对变量进行自增和自减运算,然后再按变量的新值计算表达式。按这个约定,求表达式(i-)-i 是计算 ii 的值为 0,然后再对 i 作自减运算。这样,表达式( i-)-i 的值为0。所以解答是。 13设整型变量 a、b、c 均为 2,表达式 a+

18、b+c+ 的结果是( )6 9 8 表达式出错【解】与上一小题解答的理由相同,表达式 a+b+c+被系统理解成:(a+)+(b+)+c+)。表达式“变量+“的值是变量的原来值,所以在变量 a、b c 均为 2 的前题下,执行上述表达式,得到结果为 6。所以解答是。 14若已定义 x 和 y 为 double 类型,则表达式: xl, yx32 结果是( )l 2 20 25【解】由于变量 x 和 y 都是 double 类型,表达式 xl, yx32 是先计算 x1,由于 1 是整型的,x 是 double 类型的,该计算先将整数 1 转换成 double 类型的 1.0,并将 1.0 赋给变

19、量 x。计算 yX 3 2 是先求 32 的值,因是两整数相除,结果是整型值 1,然后在计算 X1 时,也先将 1 转换成 1.0,然后求得 Xl 的值为 2.0,最后将该值赋给变量 y,并得到整个表达式的值为 2.0.所以解答是。 7 / 8115设 a=1,b=2,c3,d4 则表达式 a b?a:c d? a:d 的结果为()4 3 2 1【解】条件运算符的优先级比关系运算符的优先级低,并且它的结合性是自右向左的,所以表达式 ab?a :c d ?a:d 可用圆括号等价地写成(a b?a:(cd) ?a:d)。因 ab 成立,计算结果为 a 的值 1。所以解答是。/d)?a :d)。因

20、ab 成立,计算结果为 a 的值 1。所以解答是 。16设 a 为整型变量,下列 C 表达式中,不能表达数学关系式: 10a15 的是( )10a15 a11|a12| a13| a14a10 a 15 !(a 10)!(a=15)【解】数学关系式 10a 15 表示。只能是 11, 12, 13, 14 四个值之 l。用 C 表达式表示这个条件,可写成 a10 a15,或! (a10)&!(a =15 ),或a11|a12 | a=13|a 14 等。若写成 10a15,该算式的计算顺序是先求出10a 的结果 0 或 1,然后以这个结果与 15 比较,是否小于 15,显然这与数学式子的意义是

21、不一致的。所以解答是。 17下列表达式中,正确的 C 赋值表达式是( )a7bCa7 C7ba7a(7 b, b, a7 ) a 7b, ca7【解】赋值运算符是运算符之一,赋值运算也可以出现在一般表达式中。赋值运算时,出现在赋值运算符左边的表达式应该是引用一个存储对象,例如变量。不可以是一个数值计算表达式。如表达式 a7bc a7 因算术运算符比赋值运算符的优先级高,要把a7 的结果赋给 7bc,这是错误的。同样理由,表达式 a 7ba7 也是错误的。而表达式 a(7b ,b,a7 )就是正确的赋值表达式,它是先计算赋值号左边的括号内的表达式,括号表达式内是一个逗号表达式,远号表达式要求顺序

22、逐一计算各子表达式,并以最后一个子表达式的值作为远号表达式的结果,最后将该结果赋给变量 a。而表达式 a7b ,c a 7 则不是一个赋值表达式,而是一个逗号表达式,它由两个赋值子表达式组成。所以解答是。 8 / 8118若有以下定义: char a; int b;float c; double d;则表达式 a*b+d-c 值的类型为( )float int char double【解】基本类型的数据可以混合运算,但运算时,对要求运算分量类型相同的运算来说,如运算分量的类型不是全相同,则会有自动类型转换发生。类型自动转换规则规定类型低(简单)的向类型高(复杂)的转换。各类型由高到低的排列顺序

23、是:long double、float、unsigned long、long 、unsigned int、int 这样,若有定义: char a; int b;float c;double d;则表达式 a*b+d-c 的值的类型是 double 的。首先计算 a*b,得到 int 类型的值,接着计算 a*b+d,得到 double 类型的值,最后计算 a*b+d-c,得到 double 类型的值。所以解答是。 19表达式“9!=7“ 的值是( )true 非 0 值 0 1【解】关系运算的结果只有 0 和 1,若关系成立,则结果为 1;若关系不成立,则结果为0。因关系式 9!7 成立,所以表

24、达式的结果为 1。虽然 1 也是非 0 值,在供选择的答案中有 1,所以最确切的解答是。 20用十进制数表示表达式 “12|012“的运算结果是( )1 0 14 16【解】按位运算将运算分量视作二进位的位申信息,对两运算分量的对应位进行运算,产生 H 进位的位串信息结果。整数 12 最低 8 位二进位是 00001100,整数 012 是八进制数,它的最低 8 位二进位是 00001010。这两个二进位位串信息按位或运算,得到结果是00001110,对应十进制数 14,八进制数是 016。所以解答是。 21设字符型变量 a3,b6,计算表达式 C(a b) 2 后 C 的二进制值是( ) 0

25、0011100 00000111 00000001 00010100【解】a 的值为 3,写成 8 位二进制数形式是 00000011,b 的值为 6,写成 8 位二进制数形式是 00000110。表达式 c(a b)2,先计算 a 与 b 的按位加,得到结果 00000101,将这结果向左移 2 位,得到二进位的位串信息是 00010100。所以解答是 。 22设 a,b 和 c 都是 int 型变量,且 a3,b4,c5,则下面的表达式中值为 0 的是( )“a“b“ ab a|b+cbc !(ab)!|1)9 / 81【解】对于表达式“a“b,两个非 O 运算分量的逻辑与结果为 1。对于

26、表达式 ab,由于关系式成立,结果也为此又由于变量 a 为非 0,表达式 a|b+cbc 的结果也为 1。对于表达式!(a b)!c|1),先是计算(ab)得到结果 1;计算!C 得到结果为 0;再计算它们的逻辑与,结果为 0。继续与 1 求逻辑或,得到结果为 1。最后,对 1 求逻辑非,得到结果为 0。所以解答是。23设 Ch 是 Char 型变量,其值为“A“,则下面表达式的值是( )ch( ch“A“ch“Z“)?(ch32):ch“A“ “a“ “Z“ “z“【解】由于字符型变量 ch 的值为“ A“,计算表达式 chh“ A“ch“ Z“)?(ch 32):ch,先计算其中条件表达式

27、,由于条件(ch“Ah“Z“)成立,该条件表达式以 ch3297 为结果,将该值赋给变量 ch,以字符表达这个值为“a“。所以解答是。 /b)!|1)24 设有无符号短整型变量 i、j、k ,i 值为 013,j 值为 OX13。计算表达式“ki|j 3“后,k 的值是( ) 06 0177776 066 0177766【解】将变量 i 的八进制数值 013 写成二进制形式为 00001011,将变量 j 的十六进制值 oxl3 写成二进制数形式为 00010011。表达式 ki|j3 的计算过程是先求i ,结果用八进制代码表示为 0177764;接着计算 j3 ,结果为 02。对它们进行按位

28、或运算结果为0177766。所以解答是 。2.2 填充题1在内存中,存储字符串“X“要占用_ 个字节,存储字符“X“要占用_个字节。【解】计算机存储一个字符用 1 个字节,存储字符串时,每个字符要占用 1 个字节,另在字符串的有效字符之后存储 1 个字符串的结束标记符。所以存储字符率“X“要占用 2 个字节,存储字符“X“只要 1 个字节。 2在 C 程序中,判逻辑值时,用 _表示逻辑值“真“,又用 _表示逻辑值“假“。在求逻辑值时,用_表示逻辑表达式值为“真“,又用_ 表示逻辑表达式值为“假“。【解】在 C 程序中,判逻辑值时,用非 0 值表示真;而判逻辑值时,用值 0 表示假。但逻辑表达式

29、计算结果,逻辑表达式值为真是用 1 表示的,而逻辑表达式的值为假,则用 0 表示。 10 / 813定义符号常量的一般形式是_。【解】定义符号常量用预处理命令的宏定义,其定义的一般形式是:define 符号常量名 常量 4在函数内,说明变量时,若省略存储类型符,系统默认其为_存储类别,该存储类别的类型符为_。【解】在函数内,说明变量时,若省略存储类型符,系统就默认其为自动存储类别,该存储类别用 auto 标识。 5无符号基本整型的数据类型符为,双精度实型数据类型符为,字符型数据类型符为,。【解】无符号的基本整型的类型符为 unsigned int,或简写成 unsigned。双精度实型数据类型

30、符为 double,字符型数据类型符为 char。 6定义指定数据类型的变量时,较完整的一般形式是。【解】要指定变量的存储类型,定义指定类型的变量,其一般形式是:存储类型符数据类型符变量名 1,变量名 2,; 7设有下列运算符:、,其中优先级最高的是_,优先级最低的是_.【解】对运算符、,按它们的优先级自高到低的顺序排列为:、所以,优先级最高的是+,优先级最低的是。 8设二进制数 A 是 0A101111,若想通过异或运算 AB 使 A 的高 4 位取反,低 4 位不变,则二进制数 B 应 _。【解】按位加运算的一个重要应用是让某个整型变量的二进位位串信息的某些位信息反向,0 变成 1,而 1

31、 变成 0. 这只要设计这样一个位串信息,让要变反的位为 1,不要改变的位为0,用这个位串信息与整型变量按位加就能得到希望的结果。要使字节的高 4 位取反,低 4位不变,则需要位串信息是 11110000,写成八进制数是 0360,写成十六进制数为 0xF0。 9设 a3, b= 2,C l,则 Cb 的值为_。,a b C 的值为_ 。【解】因 a 的值为 3,b 的值是 2,条件 ah 为真,其值为 1。表达式 abc 的求值顺序是计算 ab ,结果为 1,接着计算 1c ,因 c 的值为 1,条件 1c 为假,结果为 0。 10老已知 a10 ,b20 ,则表达式! ab 的值为_ 。【解】计算表达式!ab,先计算!a ,因 a 的值为 1O,!a 的值为 0。关系表达式 020 为真,所以表达式!ab 的值为 1。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育教学资料库 > 参考答案

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。