A:
D)。
因A<B成立,计算结果为A的值1.所以解答是④。
17.下列表达式中,正确的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则不是一个赋值表达式,而是一个逗号表达式,它由两个赋值子表达式组成。
所以解答是③。
18.若有以下定义:
chara;intb;floatc;double
d;则表达式a*b+d-c值的类型为()
①float②int③char④double
「解」基本类型的数据可以混合运算,但运算时,对要求运算分量类型相同的运算来说,如运算分量的类型不是全相同,则会有自动类型转换发生。
类型自动转换规则规定类型低(简单)的向类型高(复杂)的转换。
各类型由高到低的排列顺序是:
longdouble、float、unsignedlong、long、unsignedint、int这样,若有定义:
chara;intb;floatc;doubled;则表达式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成立,所以表达式的结果为1.虽然1也是非0值,在供选择的答案中有1,所以确切的解答是④。
22.设a,b和c都是int型变量,且a=3,b
=4,c=5,则下面的表达式中值为0的是()
①‘a’&&‘b‘②a<=b③a||b+c&&b-c④!
((a
||1)
「解」对于表达式‘a’&&‘b’,两个非O运算分量的逻辑与结果为1.对于表达式a<=b,由于关系式成立,结果也为此又由于变量a为非0,表达式a||b+c&&b-c的结果也为1.对于表达式!
((a<b)&&!
c||1),先是计算(a<b)得到结果1;计算!
C得到结果为0;再计算它们的逻辑与,结果为0.继续与1求逻辑或,得到结果为1.后,对1求逻辑非,得到结果为0.所以解答是④。
23.设ch是char型变量,其值为‘A’,则下面表达式的值是()
ch=(ch>=‘A’&&ch<=‘Z’)?
(ch+32):
ch
①‘A’②‘a’③‘Z’④‘z’
「解」由于字符型变量ch的值为‘A’,计算表达式ch=h>=‘A’&&ch<=‘Z’)?
(ch+32):
ch,先计算其中条件表达式,由于条件(ch>=‘A&&h<=’Z‘)成立,该条件表达式以ch+32=97为结果,将该值赋给变量ch,以字符表达这个值为’a‘。
所以解答是②。
2.2填充题
1.在内存中,存储字符串“X”要占用______个字节,存储字符‘X’要占用_____个字节。
「解」计算机存储一个字符用1个字节,存储字符串时,每个字符要占用1个字节,另在字符串的有效字符之后存储1个字符串的结束标记符。
所以存储字符率“X‘要占用2个字节,存储字符’X‘只要1个字节。
2.在C程序中,判逻辑值时,用_____表示逻辑值“真”,又用_____表示逻辑值‘假“。
在求逻辑值时,用_____表示逻辑表达式值为”真“,又用_____表示逻辑表达式值为”假“。
「解」在C程序中,判逻辑值时,用非0值表示真;而判逻辑值时,用值0表示假。
但逻辑表达式计算结果,逻辑表达式值为真是用1表示的,而逻辑表达式的值为假,则用0表示。
3.定义符号常量的一般形式是_____.「解」定义符号常量用预处理命令的宏定义,其定义的一般形式是:
#define符号常量名常量
、5.无符号基本整型的数据类型符为_,双精度实型数据类型符为_,字符型数据类型符为_。
「解」无符号的基本整型的类型符为unsignedint,或简写成unsigned.双精度实型数据类型符为double,字符型数据类型符为char.
6.定义指定数据类型的变量时,较完整的一般形式是。
「解」要指定变量的存储类型,定义指定类型的变量,其一般形式是:
存储类型符数据类型符变量名1,变量名2,……;7.设有下列运算符:
<<、+、++、&&、<=,其中优先级高的是_____,优先级低的是_____.
「解」对运算符<<、+、++、&&、<=,按它们的优先级自高到低的顺序排列为:
++、+、<<、<=、&&所以,优先级高的是++,优先级低的是&&。
9.设a=3,b=2,c=l,则c>b的值为______.,a>b>c的值为______.
「解」因a的值为3,b的值是2,条件a>b为真,其值为1.表达式a>b>c的求值顺序是计算a>b,结果为1,接着计算1>c,因c的值为1,条件1>c为假,结果为0.
10.已知a=10,b=20,则表达式!
a<b的值为_____.
「解」计算表达式!
a<b,先计算!
a,因a的值为10,!
a的值为0.关系表达式0<20为真,所以表达式!
a<b的值为1.
11.设x和y均为int型变量,且x=l,y=2,则表达式1.0+x/y的值为_____.
解」计算表达式1.0+x/y,先求x/y,因x和y是整型变量,其中的除运算是整除,1/2的结果为0.接着计算1.0+0,计算时,先将右分量转换成0.0,后得到结果1.0.12.设整型变量x、y、z均为5:
①执“x-=y-x”后,x=__________,
②执行“x%=y+z”后,x=__________.③执行“x=(y>z)?
x+2:
x-2,3,2后,x=____________.
「解」在变量x、y、z的值均为5的情况下,计算各表达式。
由于表达式x-=y-z等价于表达式x=x-(y-z),所以计算后x的值为5.表达式x%=y+z等价于表达式x=x%(y+z),所以计算后x的值也为5.表达式x=(y>z)?
x+2:
x-2,3,
2的计算过程用圆括号描述其计算顺序是:
((x=(y>z)?
x+2:
x-2),3),2
即这是一个逗号运算表达式,由一个赋值表达式和两个数值构成,逗号表达式要求顺序求各子表达式的值。
表达式x=(y>z)?
x+2:
x-2的计算是先求赋值号右边的条件表达式,因条件(y>z)为假,求出x-2的值为3,将该值赋给变量x,使x的值为3.
13.能表述“20<x<30或x<-100”的C语言表达式是_____.
「解」首先表述20<x<30的C表达式可写成
20<x&&x<30.所以表述“20<x<30或x<-100”的C表达式为20<x&&x<30||x<-100.
14,请写出数学式x/y*z的C语言表达式
_______.
「解」数学式子表述的是x除以y乘z的积,写成C表达式可以写为x/(y*z),或可等价地写成x/y/z.
15.C语言中运算结果可以当成逻辑值使用的表达式有:
_____表达式、_______.表达式、________表达式、____________表达式、_________表达式、________表达式。
「解」在C语言中,逻辑判断以非0值为真,以0值为假。
所以,几乎所有的表达式的运算结果都可以当成逻辑值使用,如算术表达式、关系表达式、逻辑表达式、赋值表达式、逗号表达式、条件表达式等。
第三章C程序结构
3.1单项选择题
1.设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.正解的选择是②。
2.使用“scanf(”x=%f,y=%f“,&x,&y)”,要使x,y均为1.25,正确的输入是()
①1.25,1.25②1.251.25③x=1.25,y=1.25
④X=1.25y=1.25「解」格式输入函数的格式字符串中的字符可以分成三类:
空格类字符、其它普通字符和格式转换说明。
其中空格类字符用来跳过一个空格类字符序列,直至下一个非空格类字符。
普通字符要求输入字符与其完全相同。
格式转换说明对输入字符列按格式转换说明进行转换,得到内部值存储到对应输入项所指定的存储位置中。
函数调用scanf(“x=%f,y=%f,&x,&y)以普通字符x=开头,输入时也要先输入x=。
接着是一个浮点数输入格式,所有能构成一个浮点数1.25的字符序列都能满足要求。
接着是普通字符列”,y=“,在输入的浮点数之后也要有字符列”,y=“。
后又是浮点数输入格式,同样所有能构成一个浮点数1.25的字符序列都能满足要求。
问题给出的供选择答案中只有x=1.25,y=1.25是能满足上述要求的。
所以正确选择是③。
答是②。
4.设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(“c=%c,b=%c”,&c,
&b)中,普通字符必须按格式字符串要求照原样输入,c格式对紧接的任何字符都输入。
所以实现问题的要求,输入字符列应为“a=A,b=B”。
另外要特别指出,在程序中,为表示字符常量,字符前后需加单引号。
但用字符格式输入字符时,在要输入字符前后不必另键人单引号。
若键人单引号,则这个单引号也将作为字符被输入。
正确的解答是④。
和逻辑或构成的逻辑表达式有特别的计算规则,顺序计算各逻辑子表达式,并当一旦能得到逻辑表达式的结果时,就立即结束逻辑表达式的计算,不再计算后继逻辑子表达式。
本题的逻辑表达式是两个运算分量的逻辑或,而且左运算分量++x的值为非0,立即得到逻辑或运算的结果为1,并将1赋给变量t,所以变量t的值为1.正确解答为③。
6设x、y、z均为int型变量,则执行以下语句后,x、y,z的值为()x=1;y=0;z=2;y++&&++z||++x;①2、l、3②2、0、3③2、l、3④2、1、2
「解」语句序列“x=l;y=0;z=2;y++&&++z||++x;”先使变量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.正确解答为④。
7.假定所有变量均已正确定义,下列程序段运行后x的值是()
a=b=c=0;x=35;
if(!
a)x--;elseif(b);if(c)x=3;elsex=4;①34②4③35④3
「解」以变量a,b,c的值均为0,变量x的值为35,语句:
if(!
a)x--;elseif(b);if(c)x=3;elsex
=4;由两个if语句组成。
首先执行前一个if语句“if(!
a)x--;elseif(b);”,因变量a的值为0,条件!
a成立,执行x--使x的值变为34.接着执行后继的if语句“if(c)x=3;elsex=4;”,因变量c的值为0,条件不成立而执行x=4,终使变量x的值为4.正确解答是②。
注意前一个if语句的else部分的成分语句只有“if(b);”,这是一个单分支if语句,且其成分语句为空语句。
9.下列语句中,句法错误的是(不考虑语义)
()
①while(x=y)5;②dox++while(x=
=10);
③while(0);④do2;while(a==b);
「解」while语句的一般形式是:
while(表达式)语句
这里的表达式可以是任何合理的表达式,语句可以是任何语句,包括空语句,或表达式语句。
可能书写的while语句没有任何意义,如供选择的①while(x=y)5;和③while(0);,但这两个语句的句法没有任何错误。
do-while语句的一般形式是:
do语句while(表达式);
其中的成分语句也可以是任何语句,但供选择答案②dox++while(x==10);中的代码x++是一个表达式,不是语句,语句必须要以分号结束,所以是错误的。
正确解答是②。
10,循环语句“for(x=0,y=0;(y!
=123)
||(x<4);x++);”的循环执行()
①无限次②不确定次③4次④3次「解」for循环语句的初始化部分置变量x和y的初值为0,循环条件是(y!
=123)||(x<4),每次循环后变量X的值增1.由于循环过程中变量y的值未被修改过,循环条件又是一个逻辑或,其左分量(y!
=123)永远成立,也就是循环条件永远成立。
所以该循环语句将循环执行无限次。
正确解答是①。
11.若i、j已定义为int类型,则以下程序段中的内循环体的执行次数是()for(i=5;i;i--)for(j=0;j<4;j++){……}
①20②24③25④30
「解」问题所给的程序段的外循环是一个阶循环语句,它的初始化部分置变量i的初值为5,循环条件简写成i,即i!
=0,每次循环后变量i的值减1.所以外循环共控制5次循环。
内循环也是一个for循环语句,它的初始化部分置变量j的初值为0,循环条件是j<4,每次循环后变量j的值增1.所以内循环共控制4次循环。
这样,如内循环的体内未曾对变量i和j有修改,在内、外循环一起控制下,内循环体共被重复执行20次。
正确解答是①。
12.假定a和b为int型变量,则执行以下语句后b的值为()
a=1;b=10;do{b-=a;a++;}while(b--<0);
①9