C语言概念题解答选编Word格式文档下载.docx

上传人:b****2 文档编号:3660525 上传时间:2023-05-02 格式:DOCX 页数:89 大小:78.38KB
下载 相关 举报
C语言概念题解答选编Word格式文档下载.docx_第1页
第1页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第2页
第2页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第3页
第3页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第4页
第4页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第5页
第5页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第6页
第6页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第7页
第7页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第8页
第8页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第9页
第9页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第10页
第10页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第11页
第11页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第12页
第12页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第13页
第13页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第14页
第14页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第15页
第15页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第16页
第16页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第17页
第17页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第18页
第18页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第19页
第19页 / 共89页
C语言概念题解答选编Word格式文档下载.docx_第20页
第20页 / 共89页
亲,该文档总共89页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

C语言概念题解答选编Word格式文档下载.docx

《C语言概念题解答选编Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《C语言概念题解答选编Word格式文档下载.docx(89页珍藏版)》请在冰点文库上搜索。

C语言概念题解答选编Word格式文档下载.docx

②\’ 

③074 

④\0

【解】转义字符有三种书写形式:

反斜杠字符后接上某个规定的字符;

反斜杠字符后接上1至3个八进制数字符;

反斜杠字符和字符x之后接上1至2个十六进制数字符。

后两种分别以八进制数和十六进制数直接给出字符的ASCII代码值。

而074是八进制整数,不是转义字符。

所以解答是③。

6.下列字符列中,可以作为“字符串常量”的是

①ABC 

②″ABC″ 

③’abc’ 

④’a’

【解】C程序中,一个字符串常量是表示一个字符序列,书写时,用双引号字符前后括住这个字符序列。

所以只有″ABC″是一个正确的字符串常量,其余都不是。

其中,ABC可作为标识符,字符列’abc’不能出现在C程序中,’a’是一个字符常量。

7.在用一个字节存储一个字符的系统中,’\n’在内存占用的字节数是

①1 

②2 

③3 

④4

【解】一般来说,一个字符在内存中只占1个字节,’\n’是转义字符,其意义是换行符,它作为一个字符存储,在内存也只占1个字节。

8.字符串″xyz″在内存占用的字节数是

①3 

②4 

③6 

④8

【解】字符串中的每个字符占1个字节,但C程序在存储字符串时,要在最后一个有效字符后面接上1个字符串结束的标记符’\0’。

这样,存储字符串常量″xyz″需要4个字节。

9.在以下字符列中,合法的长整型常数是

①0L 

②4962710 

③0.054838743 

④2.1869e10

【解】为表示不同范围的整数,整型数据分短整型、基本型和长整型,并对三种整型内部表示的最高位的不同理解,又分别分成无符号和带符号两种。

若要明确指明一个整数是长整型的,必须在整数之后接上字符’L’。

所以0L是一个长整型的整型常量,而4962710是基本整型数据,而对于用2个字节表示一个基本整型数据的系统来说,该整数将因超出范围而是一个错误的整数;

0.054839743和2.1869e10都是double型的实数。

10.一个char型数据,它的值在内存中存放的是

①ASCII代码值 

②BCD代码值 

③内码值 

④十进制代码值

【解】计算机存储字符,通常是存储字符的某种代码值。

有许多种字符编码的方法,现在最流行的是ASCII代码。

在C语言中,char型数据在内存中存放的是ASCII代码。

11.设变量m,n,a,b,c,d均为0,执行(m=a==b)||(n=c==d)后,m,n的值是

①0,0 

②0,1 

③1,0 

④1,1

【解】计算(m=a==b)||(n=c==d)的过程是先计算逻辑或的左运算分量(m=a==b)的值,由于赋值运算符的优先级比关系运算符==的优先级低,又先计算a==b。

因a,b均为0后,所以比较结果值为1。

将1赋给变量m,使变量m的值变为1。

同时这个赋值运算的结果也是1,这样逻辑运算的左运算分量的值为1。

由于逻辑或运算的左运算分量值为1,按照C语言对逻辑或运算优化计算的规定,不再计算逻辑或的右运算分量,而直接得到逻辑或运算的结果为1。

由于逻辑或的右运算分量不曾计算过,所以变量n的值也不为变化。

这样,上述表达式计算后,变量m的值为1,变量n的值为0。

12.设a为5,执行下列语句后,b的值不为2的是

①b=a/2 

②b=6-(--a) 

③b=a%2 

④b=a<

3?

3:

2

【解】因两个整型数据相除,结果是整数,当a的值为5时,计算表达式b=a/2后,使b的值为2。

计算表达式b=6-(--a)是先计算子表达式(--a),先让a的值减1变成4,并以减1后的a为子表达式的结果,所以子表达式的结果为4,最后使b的值为2。

在计算表达式b= 

a%2时,求余运算a%2的结果为1,最后使变量b的值为1。

计算表达式b=a<

3:

2时,先计算条件表达式a<

2,以2为结果,最后也使变量b的值为2。

13.执行语句“x=(a=3,b=a--);

”后,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。

14.设整型变量m,n,a,b,c,d均为1,执行“(m=a>

b)&

&

(n=a>

b)”后,m,n的值是

①0,0②0,1 

【解】表达式(m=a>

b)是一个逻辑表达式,它的计算过程是先计算逻辑与的左分量(m=a>

b),其中又是先计算a>

b。

因a>

b不成立,结果为0,将0赋给变量m,最后逻辑与的左分量结果为0。

由于逻辑运算采用特别的优化计算规则,当逻辑与的左分量结果为0时,不再计算逻辑与的右分量,而直接以0为逻辑与的结果。

所以,上述表达式计算使m的值变为0,而n的值没有变,依旧为1。

15.设有语句“inta=3;

”,则执行了语句“a+=a-=a*a;

”后,变量a的值是

②0 

③9 

④-12

【解】由于赋值运算符的结合性自右至左,语句“a+=a-=a*a;

”的执行是先计算a*a,得到值9,再计算a-=a*a,使a的值为-6,接着计算a+=a,使a的值为-12。

16.在以下一组运算符中,优先级最高的运算符是

①<

②= 

③% 

④&

【解】常规运算符的优先级自高到低的排列顺序是算术运算符、移位运算符、关系运算符、按位运算符、逻辑运算符、条件运算符、赋值运算符、逗号运算符。

所以问题所给的四个运算符按优先级自高到低的排列顺序是%,<

=,&

,=。

17.设整型变量i的值为3,则计算表达式i---i后表达式的值为

①0 

②1 

③2 

④表达式出错

【解】有些运算符只有一个字符,也有许多运算符由两个字符组成。

特别是有些字符既可是单个字符的运算符,又能组成双字符的运算符。

编译系统在识别源程序时,通常是尽量多地读入字符,能组成多字符单词的先尽量组成多字符单词。

所以表达式i---i,被编译器理解为(i--)-i。

另外,当表达式中某变量有后缀自增和自减运算时,先按变量的原值计算表达式,然后再对变量进行自增和自减运算。

同样地,当表达式中某变量有前缀自增和自减运算时,先对变量进行自增和自减运算,然后再按变量的新值计算表达式。

按这个约定,求表达式(i--)-i是计算i-i的值为0,然后再对i作自减运算。

这样,表达式(i--)-i的值为0。

18.设整型变量a、b、c均为2,表达式a+++b+++c++的结果是

①6 

②9 

③8 

【解】与上一小题解答的理由相同,表达式a+++b+++c++被系统理解成:

((a++)+(b++))+(c++)。

表达式“变量++”的值是变量的原来值,所以在变量a、b、c均为2的前题下,执行上述表达式,得到结果为6。

19.若已定义x和y为double类型,则表达式:

x=1,y=x+3/2的结果是

③2.0 

④2.5

【解】由于变量x和y都是double类型,表达式x=1,y=x+3/2是先计算x=1,由于1是整型的,x是double类型的,该计算先将整数1转换成double类型的1.0L,并将1.0L赋给变量x。

计算y=x+3/2是先求3/2的值,因是两整数相除,结果是整型值1,然后在计算x+1时,也先将1转换成1.0L,然后求得x+1的值为2.0L,最后将该值赋给变量y,并得到整个表达式的值为2.0L,简写成2.0。

20.设a=1,b=2,c=3,d=4,则表达式a<

b?

a:

c<

d?

d的结果为

①4 

②3 

④1

【解】条件运算符的优先级比关系运算符的优先级低,并且它的结合性是自右向左的,所以表达式a<

d可用圆括号等价地写成(a<

b)?

((c<

d)?

d)。

因a<

b成立,计算结果为a的值1。

21.设a为整型变量,下列C表达式中,不能表达数学关系式:

10<

a<

15的是

①10<

15 

②a==11||a==12||a==13||a==14

③a>

10&

④!

(a<

=10)&

!

(a>

=15)

【解】数学关系式10<

15表示a只能是11,12,13,14四个值之1。

用C表达式表示这个条件,可写成a>

a<

15,或!

=15),或a==11||a==12||a==13||a==14等。

若写成10<

15,该算式的计算顺序是先求出10<

a的结果0或1,然后以这个结果与15比较,是否小于15,显然这与数学式子的意义是不一致的。

22.下列表达式中,正确的C赋值表达式是

①a=7+b+c=a+7 

②a=7+b++=a+7 

③a=(7+b,b++,a+7) 

④a=7+b,c=a+7

【解】赋值运算符是运算符之一,赋值运算也可以出现在表达式中。

赋值运算时,出现在赋值运算符左边的表达式应该是引用一个存储对象,例如变量。

不可以是一个数值计算表达式。

如表达式a=7+b+c=a+7因算术运算符比赋值运算符的优先级高,要把a+7的结果赋给7+b+c,这是错误的。

同样理由,表达式a=7+b++=a+7也是错误的。

而表达式a=(7+b,b++,a+7)就是正确的赋值表达式,它是先计算赋值号左边的括号表达式,括号表达式内是一个逗号表达式,逗号表达式要求顺序逐一计算各子表达式,并以最后一个子表达式的值作为逗号表达式的结果,最后将该结果赋给变量a。

而表达式a=7+b,c=a+7则不是一个赋值表达式,而是一个逗号表达式,它由两个赋值子表达式组成。

23.若有以下定义:

chara;

intb;

floatc;

doubled;

则表达式a*b+d-c值的类型为

①float 

②int 

③char 

④double

【解】基本类型的数据可以混合运算,但运算时,对要求运算分量类型相同的运算来说,如运算分量的类型不是全相同,则会有自动类型转换发生。

类型自动转换规则规定类型低(简单)的向类型高(复杂)的转换。

各类型由高到低的排列顺序是:

longdouble、double、float、unsignedlong、long、unsignedint、int。

这样,若有定义:

则表达式a*b+d-c的值的类型是double的。

首先计算a*b,得到int类型的值,接着计算a*b+d,得到double类型的值,最后计算a*b+d-c,得到double类型的值。

24.表达式“9!

=7”的值是

① 

true 

②非0值③0 

【解】关系运算的结果只有0和1,若关系成立,则结果为1;

若关系不成立,则结果为0。

因关系式9!

=7成立,所以表达式的结果为1。

虽然1也是非0值,在供选择的答案中有1,所以最确切的解答是④。

25.用十进制数表示表达式“12|012”的运算结果是

①1 

③14 

④16

【解】按位运算将运算分量视作二进位的位串信息,对两运算分量的对应位进行运算,产生二进位的位串信息结果。

整数12最低8位二进位是00001100,整数012是八进制数,它的最低8位二进位是00001010。

这两个二进位位串信息按位或运算,得到结果是00001110,对应十进制数14,八进制数是016。

26.设字符型变量a=3,b=6,计算表达式c=(a^b)<

<

2后c的二进制值是

①00011100 

②00000111 

③00000001 

④00010100

【解】a的值为3,写成8位二进制数形式是00000011,b的值为6,写成8位二进制数形式是00000110。

表达式c=(a^b)<

2,先计算a与b的按位加,得到结果00000101,将这结果向左移2位,得到二进位的位串信息是00010100。

27.设a,b和c都是int型变量,且a=3,b=4,c=5,则下面的表达式中值为0的是

①’a’&

’b’ 

②a<

=b 

③a||b+c&

b-c 

((a<

!

c||1)

【解】对于表达式’a’&

’b’,两个非0运算分量的逻辑与结果为1。

对于表达式a<

=b,由于关系式成立,结果也为1。

又由于变量a为非0,表达式a||b+c&

b-c的结果也为1。

对于表达式!

c||1),先是计算(a<

b)得到结果1;

计算!

c得到结果为0;

再计算它们的逻辑与,结果为0。

继续与1求逻辑或,得到结果为1。

最后,对1求逻辑非,得到结果为0。

28.设ch是char型变量,其值为’A’,则下面表达式的值是

ch=(ch>

=’A’&

ch<

=’Z’)?

(ch-‘A’+’a’):

ch

①A 

②a 

③Z 

④z

【解】由于字符型变量ch的值为’A’,计算表达式ch=(ch>

(ch+32):

ch,先计算其中条件表达式,由于条件(ch>

=’Z’)成立,该条件表达式以ch+32=97为结果,将该值赋给变量ch,以字符表达这个值为’a’。

所以解答是②。

29.设有无符号整型变量i、j、k,i值为013,j值为0x13。

计算表达式“k=~i|j>

>

3;

”后,k的值是

①06 

②0177776 

③066 

④0177766

【解】将变量i的八进制数值013写成二进制形式为00001011,将变量j的十六进制值0x13写成二进制数形式为00010011。

表达式k=~i|j>

3的计算过程是先求~i,结果用八进制代码表示为0177764;

接着计算j>

3,结果为02。

对它们进行按位或运算结果为0177766。

30.设a=3,b=4,执行“printf(“%d,%d”,(a,b),(b,a));

”的输出是

①3,4 

②4,3 

③3,3 

④4,4

【解】在调用格式输出函数的语句中,其中每个格式符对应一个输出项,格式符d要求输出项内容以十进制整数形式输出。

语句中的第一个格式符对应输出项(a,b)是一个逗号表达式,该表达式的值是b的值,所以先输出4。

接着输出字符逗号。

同样输出项(b,a)的值是a的值,输出3。

所以语句执行将输出4,3。

正解的选择是②。

31.使用“scanf(“x=%f,y=%f”,&

x,&

y)”,要使x,y均为1.25,正确的输入是

1.25,1.25 

②1.25 

1.25 

③x=1.25,y=1.25 

④x=1.25 

y=1.25

【解】格式输入函数的格式字符串中的字符可以分成三类:

空格类字符、其它普通字符和格式转换说明。

其中空格类字符用来自动跳过空格类字符,直至下一个非空格类字符。

普通字符要求输入字符与其完全相同。

格式转换说明对输入字符列按格式转换说明进行转换,得到内部值存储到对应输入项所指定的存储位置中。

格式输入函数调用scanf(“x=%f,y=%f”,&

y)以普通字符x=开头,输入时也要先输入x=。

接着是一个浮点数输入格式,所有能构成一个浮点数1.25的字符序列都能满足要求。

接着是普通字符列“,y=”,在输入的浮点数之后也要有字符列“,y=”。

最后又是浮点数输入格式,同样所有能构成一个浮点数1.25的字符序列都能满足要求。

问题给出的供选择答案中只有x=1.25,y=1.25是正确的输入。

所以选择③。

通常,格式输入函数调用中,不在格式字符串插入普通字符,要求输入与格式中的普通字符匹配的字符,而是简洁地写上输入格式即可。

32.设a,b为字符型变量,执行“scanf(“a=%c,b=%c”,&

a,&

b)”后使a为’A’,b为’B’,从键盘上的正确输入是

①‘A’’B’ 

②‘A’,’B’ 

③A=A,B=B 

④a=A,b=B

【解】函数调用scanf(“a=%c,b=%c”,&

b)中,普通字符必须按格式字符串要求照原样输入,c格式对紧接的任何字符都输入。

所以实现问题的要求,输入字符列应为“a=A,b=B”。

另外要特别指出,在程序中,为表示字符常量,字符前后需加单引号。

但用字符格式输入字符时,在要输入字符前后不必另键入单引号。

若键入单引号,则这个单引号也将作为字符被输入。

正确的解答是④。

33.设有inti=010,j=10;

则执行“printf(“%d,%d\n”,++i,j--);

①11,10 

②9,10 

③010,9 

④10,9

【解】变量i和j的初值分别为八进制数010和十进制数10,格式输出函数调用printf(“%d,%d\n”,++i,j--)中,++i的值是变量i增1后的值,原来值是八进制数010,等于十进制数8,输出9。

j--的值是变量j减1之前的值,输出10。

格式字符串中的逗号是普通字符照原样输出。

所以问题给出的格式输出函数调用将输出9,10。

正确的解答是②

34.设有inti=010,j=10;

正确的解答是②。

35.设x、y、z、t均为int型变量,则执行以下语句后,t的值为

x=y=z=1;

t=++x||++y&

++z;

①不定值 

③1 

④0

【解】语句序列“x=y=z=1;

++z;

”使变量x的值为1,变量t是赋一个逻辑表达式的值。

在C语言中,由逻辑与和逻辑或构成的逻辑表达式有特别的计算规则,顺序计算各逻辑子表达式,并当一旦能得到逻辑表达式的结果时,就立即结束逻辑表达式的计算,不再计算后继逻辑子表达式。

本题的逻辑表达式是两个运算分量的逻辑或,而且左运算分量++x的值为非0,立即得到逻辑或运算的结果为1,并将1赋给变量t,所以变量t的值为1。

正确解答为③。

36.设x、y、z均为int型变量,则执行以下语句后,x、y、z的值为

x=1;

y=0;

z=2;

y++&

++z||++x;

①2、1、3 

②2、0、3 

③2、1、3 

④2、1、2

【解】语句序列“x=1;

”先使变量x的值为1,变量y的值为0,变量z的值为2。

由逻辑与和逻辑或构成的逻辑表达式的特别计算规则,顺序计算各逻辑子表达式,并当一旦能得到逻辑子表达式的结果时,就立即结束逻辑子表达式的计算,不再计算该逻辑子表达式。

计算y++因y的值为0,使y++&

++z的结果为0,立即去计算++x,这次计算使变量y的值变成1,而变量z的值未改变。

接着计算++x,使x的值变为2。

所以经上述语句执行后,x、y、z的值依次为2、1、2。

正确解答为④。

37.假定所有变量均已正确定义,下列程序段运行后x的值是

a=b=c=0;

x=35;

if(!

a)x--;

elseif(b);

if(c)x=3;

elsex=4;

①34 

③35 

④3

【解】以变量a,b,c的值均为0,变量x的值为35,语句:

由两个if语句组成。

首先执行前一个if语句“if(!

elseif(b);

”,因变量a的值为0,条件!

a成立,执行x--使x的值变为34。

接着执行后继的if语句“if(c)x=3;

”,因变量c的值为0,条件不成立而执行x=4,最终使变量x的值为4。

正确解答是②。

注意前一个if语句的else部分的成分语句只有“if(b);

”,这是一个单分支if语句,且其成分语句为空语句。

38.下面的程序段所表示

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 高中教育 > 高考

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2