当前位置:文档之家› C详细答案复习题c

C详细答案复习题c

C详细答案复习题c
C详细答案复习题c

第3章运算符和表达式

丰富的运算符可使表达式方便、简捷。初学者一下掌握这么多操作符会有压力。可通过写或计算表达式的练习,以及各章程序实例中出现的表达式,进一步熟悉运算符。

3.1 表达式的基本概念

对数据进行各种运算的符号为运算符,参与运算的数据为操作数。表达式构成:常量、变量、有返回值的函数调用是表达式,表达式加圆括号、或用运算符作正确连接后也是表达式。

圆括号左、右括号个数要相同,多层括号时内层括号中的运算优先;整个表达式必须写在同一行上。

a·x3+b·x2+c·x+d 写作

a*x*x*x+b*x*x+c*x+d 或 ((a*x+b)*x+c)*x+d;

写作 1/(1+1/(1+x));等等。

C运算符:算术、关系、逻辑、条件、赋值、逗号运算符,等等。

根据参与运算的操作数个数,运算符可分为单目、双目以及三目运算符。两个操作数的运算符是双目运算符,“单目运算符”只有一个操作数。三目运算符是C语言所特有的,它有三个操作数。

不同运算符参与运算时有优先级问题。如先乘除、后加减。

同级运算一般是从左向右进行。特例如赋值“x=y=3”,先计算y=3、再计算x=y。特例将特别指出,一般按缺省。

主要介绍算术(包括自增自减)、关系、逻辑、赋值、逗号运算符,以及由这些运算符构成的各类表达式。

3.2 算术运算符与算术表达式

内容:算术运算符及其功能,算术表达式,优先级、运算时的类型转换规则。

3.2.1 算术运算符

1. 算术运算符

C的算术运算符有:+ - * / %(取余)

其中“-”可作单目运算符,如-5,表达式3*-5值为-15。

各运算符优先级:先乘除、后加减;取余的优先级和乘除相同。

优先级的讨论,应限于同一层括号内,同级运算一般从左到右执行。具体规则如下:

?字符类型数据以该字符的ASCII值参加运算,参与运算的字符可以看作一个特殊的整型数。如12.5+'A'的值为77.5,其中'A'以该字符ASCII值65参加运算。

?各种类型数据作算术运算的有关规则,详见下页“2. 算术运算中的类型转换”。特别要注意的是,两个整型数据作“/”运算时,结果是整数。

比如:5/4的结果是1,而5.0/4的结果为1.25。

灵活地应用/的整除性质,有助于我们对整型量作一些特殊处理。例如,求整型变量k的十位上的数,可以写作k%100/10(验证:给定k如1765代入,k%100得65,65/10得6)。

?% 只能用于整数和字符的运算,不能用于实型数据。

比如:2%3结果为2,34%5的结果为4,'A'%6结果为5。

用算术运算符和括号将运算对象连接起来、符合C语法规则的式子称C算术表达式。运算对象包括常量、变量、函数等。如下面是合法的表达式:

例1.C的算术表达式示例

[1+x(a+b)1/3]*x 写作:(1+x*(pow(a+b,1.0/3)))*x

写作:cos(y/sqrt(x*x+y*y))

求整型变量m个、十、百位之和,写作: m%10+m/10%10+m/100%10

2. 算术运算中的类型转换

⑴自动类型转换

同一表达式中参与运算的变量和常量可能有不同类型:C需要自动转换其中一个操作数值的类型,与另一操作数相同后参加运算。

一般转换规则:char→short→int→float→ double

即:参加运算的表达式类型转换至其中字长最长的数据类型;同样字长的情况下的转换应保证计算结果的精度。

如:计算表达式12-'3',则先将字符常量转换为int类型,表达式的值为-39(因为字符'3'的ASCII值为51)。

又如:声明为float pi=3.14159; int d=180;时计算 pi/d;相除的两操作数字长相同,转换d为float类型后,再作除法运算。

注意:每次转换只涉及参与运算的两个操作数。如计算5/3+3.9的结果是4.9。计算5/3时,执行的还是整除运算,结果为1;在计算1+3.9的时候,才把整数1转换为double类型,和3.9相加。

⑵强制类型转换

除了自动实现类型转换外,还可强制类型转换,其格式为:(类型标识符)表达式

int类型变量i、j相除,写作(float)i/j、(double)i/j,运算结果分别为float、double类型。

对表达式中变量而言,无论是自动或强制类型转换,仅是为本次运算需要,而不改变变量类型。如计算(float)i/j并未改变声明为int类型的变量i为float类型。

41 / 11

例2. 按照下列要求,写出相应C的算术表达式。

设x是正实数,写出不大于x的最大整数。写作:(int)x

计算float类型变量x的整数部分与y的小数部分之和。写作:(int)x+y-(int)y

求正整数m的位数。写作:(int)log10(m)+1

3.2.2 自增、自减运算

自增、自减运算是特殊的算术赋值运算,且只能用于整型变量。自增运算符为++,自减运算符为--。

前缀格式运算符变量后缀格式变量运算符

功能:前缀格式先使变量加(减)1,再用其值参加所在表达式运算;后缀格式则反之。

如果单独使用,前缀、后缀格式没有区别。如i++和++i都表示i=i+1, i--和--i也是同样。但当自增、自减运算作为某个表达式的一个组成部分时,不同格式会产生不同效果:

①②

int x=3,y; int x=3,y;

y=--x+3; y=x--+3;

printf("%d %d\n",x,y); printf("%d %d\n",x,y);

①:先执行x=x-1,x当前值2;再执行y=x+3,x为2、y为5;

②:先执行y=x+3,x当前值为3;再执行x=x-1,x为2、y为6。

例3. 分析下面程序的运行结果。

#include

void main()

{ int a,b,c;

a=2;b=2;c=++a+b--;

printf("a=%d,b=%d,c=%d\n",a,b,c);

a=2; b=2; c=-a---b;

printf("a=%d,b=%d,c=%d\n",a,b,c);

a=2; b=2; printf("a=%d\t",a++);

printf("b=%d\t",++b);

c=a+b; printf("c=%d\n",c);

}

【运行结果】 a=3,b=1,c=5

a=1,b=2,c=-4

a=2 b=3 c=6

通过以上例题,可以得出关于自增、自减运算优先级的结论:表达式中前缀格式自增、自减运算符的优先级,高于表达式中其它运算符;表达式中后缀格式自增、自减运算符的优先级,低于表达式中其它运算符。

例4.运行下列程序,分析结果。

#include

void main()

{ int i=6,j=6,k,m;

k=++i+i+++i++;

m=j+++j+++j++;

printf("i=%d j=%d\n k=%d m=%d\n",i,j,k,m);

}

【运行结果】 i=9 j=9

k=21 m=18

【程序说明】在BC++或其他运行环境下可能会得出不同结果。

同一个程序,在不同的运行环境中得到不同结果。在保证程序正确性的前提下,应以易读性标准为第一。建议不要用自增、自减运算构造颇具复杂性的表达式,以避免损害程序易读性而导致错误。

3.3 赋值运算符与赋值表达式

通过赋值运算,可以把一个表达式的值赋给一个变量,赋值的对象只能是变量(包括下标变量)。

3.3.1 赋值运算符

格式:变量名=表达式

能:先计算表达式的值,再将计算结果送给变量。

赋值表达式后加分号即为赋值语句,即:变量名=表达式;

例如a=1+2*3.14159;执行步骤:计算1+2*3.14159的值赋给a。

注意:

?“=”左边只能是变量,3=x;、3+x=y;都不是合法的语句。

?赋值运算自右向左

语句a=b=c=5;先执行c=5再执行b=c,最后执行a=b。

建议不要写出类似“i=(k=j+1)+(j=5);”的赋值语句,因为不同系统处理可能不同,先执行k=j+1或先执行j=5会导致不同结果。

3.3.2 赋值运算时的数据类型转换

1.数据类型的赋值转换

在x=e中,若x与e类型不同,C会自动完成类型转换:将表达式的值转换为与变量同类型的数据再赋值,具体规则如表2-4所示。

若x是值为3的int类型变量,则表达式x=x+1.8的值是4。

若c是字符变量,执行c=1345;putchar(c);后输出字符A。因为整数1345的补码00000000 00000000 00000101 01000001,赋值给单字节的c,只能取其低字节内容01000001,为65。

2.有符号数和无符号数的转换问题

因为两者编码上有差异,当有符号整数赋值给无符号整型变量时会产生变化,例如声明short a=-1;unsigned short b;,执行语句b=a;后b的值为65535。

因为值为-1的短整型数的补码表示为11111111 11111111,如赋值给b, b的编码也是11111111 11111111。由于b是一个无符号数,其最高位的1代表一个正的值215,所以b的值为65535。

43 / 11

short a=1;unsigned short b;执行语句b=a;后b的值也是1。

3.3.3 复合算术赋值运算

形如i=i+2、s=s*(x-9.81)的算术赋值语句,C提供了缩写的运算符,表示为i+=2、s*=x-9.81。

实际是算术、位运算等运算符与赋值运算符的合成、简化,称为复合赋值运算符。

+= 复合加赋值) -= 复合减赋值 *= 复合乘赋值

/= 复合除赋值 %= 复合取余赋值

例如:a+=3等价于a=a+3,x*=y+8等价于x=x*(y+8),y/=4等价于y=y/4,m%=3等价于m=m%3。

注意:在运算中,表达式作为运算的一个整体。如s*=x-9.81 等同于s=s*(x-9.81),不能理解为s=s*x-9.81。

不是非使用不可,初学者可少用、不用复合赋值运算符。但作为C程序员,应理解这些运算符。

3.4 关系运算符、逻辑运算符与逻辑表达式

程序中,往往需要根据某些条件作出判断,由条件的成立(真)与否(假)决定流程。C中用逻辑表达式来实现条件判断。

用关系运算符可构成关系表达式。关系表达式的值是逻辑值,因此关系表达式也是逻辑表达式。逻辑表达式用逻辑运算符做正确连接后,也是逻辑表达式。

C中逻辑表达式使用广泛。if语句根据其中逻辑表达式的值决定执行哪一个分支,循环语句for、while要根据其中逻辑表达式值决定循环过程是否继续。

如何根据条件写出C逻辑表达式,是本节学习应掌握的内容。

3.4.1 关系运算符

关系运算是双目运算,用于比较两个运算量间的大小关系。

关系表达式格式:表达式关系运算符表达式

关系表达式成立,其值为1;关系表达式不成立,其值为0。

1.关系运算符

> >= < <= == !=

运算结果:成立为1,不成立为0。

关系表达式也是逻辑表达式。

例如下列语句作用是输出i、i+1、i+2、…,当i为21时终止。

while(i<=20) {

printf("%d\n",i); i++;

}

关系运算符比较两操作数的数量关系。如i<=20,若i不大于20那么表达式的值为1(真);否则为0(假)。

易犯错误:误将==写作=。x==3和x=3完全不同!前者判断x和

3是否相等,是关系运算,对x的值并没有影响;后者是赋值运算,经过赋值后,x的值为3。

一般不对实型数作相等或不等判断。由于浮点编码的特殊性,某些实数(如0.3、0.6等)在用浮点格式存储的时候并不能精确表示,造成在运算时有一定的误差积累。

例5. 从0度起直到60度,每间隔0.6度输出正弦函数值。

#include

#include

void main()

{ float deg=0;

while(deg!=60) {

printf("sin(%.6f)=%.6f\n",deg,sin(deg*3.141593/180)); deg=deg+0.6;

}

}

【运行结果】没完没了。将 deg!=60 改写作deg<=60

2. 优先级

⑴“>、>=、<、<=”的优先级高于“==、!=”

x>5!=1 若x大于5,表达式x>5值为1,再计算1!=1结果为0。

k-2==y-4<5 若k、y值分别为3、6,左式相当于1==2<5。==低于<,先计算2<5得1,再计算1==1,关系表达式的计算结果为1。

⑵在算术运算符和关系运算符中讨论,在同一层括号内各运算符的优先级依次为:

① *、/、% ②(双目运算)+、- ③ >、>=、<、<= ④ ==、!=

3.4.2 逻辑运算符和表达式

1. C的逻辑运算符和表达式

逻辑运算判断运算对象的逻辑关系,运算对象为关系表达式或逻辑量。

!(逻辑非) && (逻辑与) || (逻辑或)

⑴逻辑非

格式:!表达式

功能:表达式为0则!表达式值为1,否则为0。

将条件“x不大于3”写作逻辑表达式,表示为!(x>3)。

⑵逻辑与

格式:表达式 && 表达式

功能:两边表达式值均为非0,则结果为1;否则结果为0。

“n是一个两位正整数”表示为n>9 && n<100。

当“-3

if(x>-3 && x<3) printf("%f\n",x);

将-3

⑶逻辑或

45 / 11

格式:表达式 || 表达式

功能:若表达式值全为0则结果为0,否则结果为1。

条件“x绝对值大于6.25”写作x>6.25||x<-6.25。

2.逻辑表达式

用逻辑运算符将关系表达式或其他逻辑量连接起来是逻辑表达式,运算结果是逻辑意义上的“真”或“假”。

关系运算的结果“成立”或“不成立”等价于逻辑意义上的“真”或“假”,关系表达式是逻辑表达式的一种特殊形式。

⑴逻辑表达式的结果只有1(真)或0(假)

C没有表示逻辑值的数据类型,用1代表“真”,用0代表“假”。

⑵在判断运算对象的真、假时,将非零数值当作真,0当作假。

注意区分⑴、⑵:前者,C计算逻辑表达式的结果(很规范,真为1假为0);后者,应出现逻辑表达式处出现了0、1以外的数据,C是如何处理的(很宽容,非零作1)

语句if(x) y=1.0/x;中x作逻辑表达式使用,x非0代表“真”即条件成立。语句含义是:x不等于0则计算y=1.0/x。

该语句等价于“if(x!=0) y=1.0/x;”。

语句if(n%2) printf("odd numbers.\n");中n%2同样起逻辑表达式作用。n是奇数n%2值为1代表“真”;n是偶数代表“假”。语句作用:判断n是奇数还是偶数决定是否输出“odd numbers”。

n=10;s=0;while(n>0)s=s+n--;与n=10;s=0;while(n)s=s+n--;完全等价,后者中“while(n)”可以理解为“while(n!=0)”。

⑶各逻辑运算符优先级从高到低依次为:!、&&、||

将“x大于5且|y|>6”写作y>6||y<-6 && x>5是错误的,因为与优先于或,只要y大于6则表达式值为1、与x是否大于5无关。加括号可以改变运算顺序。可写作:(y>6||y<-6) && x>5 在算术、关系和逻辑运算符中讨论,在同一层括号内各运算符的优先级依次为:

① ! ② *、/、% ③ +、-

④ >、>=、<、<= ⑤ ==、!= ⑥ && ⑦ ||

例6. 根据下列条件,写出C的逻辑表达式。

?“x不等于0”,写作:x!=0 或 !(x==0)

?“m、n都能被k整除”,写作:m%k==0 && n%k==0

?“长度分别为a、b、c的三条线段能够组成三角形”,写作: a+b>c && a+c>b && b+c>a

?“x、y 落在圆心在(0,0)、半径为 r1 的圆外和半径为 r2 的圆内”,写作:

x*x+y*y>=r1*r1 && x*x+y*y<=r2*r2

⑷ C未必执行逻辑表达式中的所有逻辑运算

注意:在由&&和||运算符组成的逻辑表达式中,为提高执行效率,规定只对能确定全式结果的最少数目的子表达式计算,即若某子表达式值可确定整个表达式值,后面的子表达式就不再计算了。

例如: int x=y=z=0; ++x&&++y||++z;

由于++x&&++y为1,不管||后面是什么值,++x&&++y||++z的值肯定都是1。因此式中的++z被忽略。结果是:表达式值为1,x为1、y为1,z保持初值0不变。

又如: int x=y=z=-1; ++x&&++y&&++z;

由于++x为0,不管&&后面的++y是何值,++x&&++y肯定是0,因此++y被忽略;由于++x&&++y的值是0,不管下一个&&后面的++z是何值,++x&&++y&&++z肯定是0,因此++z也被忽略。结果是:表达式值为0,x为0、y、z保持初值-1不变。

3.5 条件表达式与逗号表达式

3.5.1 条件表达式

条件运算是根据给定逻辑表达式,在两个表达式中取其中一个表达式值的运算。

格式:逻辑表达式?表达式1:表达式2

功能:若逻辑表达式值非0,则以表达式1的值为条件表达式值;否则以表达式2的值为条件表达式值。

为变量z赋值x、y中较大值,写作z=x>y?x:y

取变量t的符号(-1或1),写作t>=0?1:-1

为变量s赋值x、y、z中较大值,写作s=(s=x>y?x:y)>z?s:z

若字符变量ch为小写字母则改为大写字母,写作:

ch=(ch>='a' && ch<='z' ? ch+'A'-'a':ch) 【注】条件表达式由三个表达式构造,各表达式中后缀格式的自增、自减运算,在各表达式的其它运算完成之后进行。

如:i=3; j=7; i=(i++>j)?i:j; 运算结束后i为7、j为7。

计算“i++>j”,先用i当前值作比较,后执行i的自增运算,再判断为i赋何值。不是在所有运算的最后再执行i的自增运算。

条件表达式由多个表达式组成,讨论的其中自增、自减运算的优先级问题,应就各个表达式讨论。

例7. 下列程序输入变量a、b、c 后,按值从大到小输出。

#include

void main()

{ float a,b,c,max,mid,min;

scanf("%f%f%f",&a,&b,&c);

max=(max=a>b?a:b)>c?max:c;

min=(min=a

mid=a+b+c-max-min;

printf("%f %f %f\n",max,mid,min);

}

3.5.2 逗号表达式

格式:表达式1,表达式2

功能:先计算表达式1,再计算表达式2,表达式2值为结果

47 / 11

例如:若a的值为2,语句“c=(b=a++,b=a+2);”的执行步骤...

按此格式,可知若干个表达式用逗号间隔,也是逗号表达式。

例如执行语句“x=(a=3,b=5,b+=a,c=b*5);”后,变量x、a、b、c的值依次为40、3、8、40,整个表达式的值也是40(x最后的值)。

不提倡过多使用。如c=(a=1,b=++a);写作a=1;b=++a;c=b;为宜。

3.6 小结

主要介绍C的运算符和表达式。

C的运算符包括算术、关系、逻辑、赋值和条件运算符,等等。表达式是用运算符和圆括号将操作数连接在一起的式子。

运算符有不同优先级(见附录II),不同类型数据运算时要按一定规则进行类型转换,在书写或计算C的表达式要加以注意。

C中逻辑表达式的值只能是0或1。关系表达式可以直接作为逻辑表达式,算术表达式也可作为特殊的逻辑表达式。

在语句if(k-5) x=y;中,k-5作逻辑表达式、等价于k-5!=0;在语句v=k-5;中被视为算术表达式。表达式的含义,需要结合程序上下文考虑。

习题三

1. 根据下列数学式,写出C的算术表达式。

2. 按照要求写出下列C的表达式。

⑴数学式 (x+1)e2X所对应的C算术表达式。

⑵将double类型变量x的整数部分与y的小数部分相加的算术表达式。

⑶将非零实型变量x四舍五入到小数点后2位的算术表达式。

⑷为变量s赋值:取变量x 的符号,取变量y的绝对值。

⑸条件“-5≤x≤3”所对应的C逻辑表达式。

⑹ a、b是字符变量,已知a的值为大写字母、b的值为小写字母,写出判断a、b是否为同一字母的逻辑表达式

⑺ int类型变量a、b均为两位正整数,写出判断a的个位数等于b的十位数、且b的个位数等于a的十位数的逻辑表达式。

⑻计算变量a、b中较小值的条件表达式。

⑼判断变量ch 是英文字母的表达式;

⑽若字符变量ch的值为大写字母,则重新赋值为对应的小写字母。

3. 声明“int k=12;float x=9.5;double d=2.7;char zf='B';”,写出下列表达式值。

⑴ (int)x%k*d ⑵ k+5.6

⑷ !k&&x>d ⑸ zf='B' ⑹ zf=='B'

4. 填空题

⑴声明“float x=2.5,y=4.7; int a=7;”,表达式

x+a%3*(int)(x+y)%2/4值为。

⑵设有整型变量a, b,c,其中a、b的值分别为10与20,计算“c=(a%2==0)?a:b;”后,c的值为。

⑶设有整型变量d的值为7,表达式“3

⑷已知ch是字符变量。如果ch是小写英文字母,则把它改成大写英文字母,写作:

if( )ch=ch-32;

⑸下列程序的输出结果是。

#include

void main( )

{ int y;

double d=3.4, x;

x=(y=d/2.0)/2;

printf(" (%0.2f, %d) ", x, y);

}

⑹判断a、b是否绝对值相等而符号相反的逻辑表达式为。

⑺判断变量a、b中必有且只有一个为0的逻辑表达式为。

⑻ c初值为3,计算赋值表达式“a=5+(c+=6)”后表达式值、a、c的值依次为。

⑼求解赋值表达式“a=(b=10)%(c=6)”后,表达式值、a、b、c的值依次为。

⑽求解逗号表达式“x=a=3,6*a”后,表达式值、x、a的值依次为。

⑾若a=13、b=25、c=-17,表达式“((y=(a

⑿若s='d',执行语句“s=(s>='a'&&s<='z')?s-32:s;”后字符变量s的值为。

5. 写出下列程序的输出结果。

程序⑴ #include

void main()

{ unsigned k,n;

scanf("%u",&n);

k=n%10*10+n/10;

printf("n=%d k=%d\n",n,k);

}

运行时输入数据为:69 72 输出结果为:

程序⑵ #include

void main()

{ int x=40,y=4,z=4;

x=y==z;

printf("%d %d %d\n",x,y,z);

49 / 11

x=x==(y=z);

printf("%d %d %d\n",x,y,z);

}

输出结果为:

程序⑶ #include

void main()

{ int x,y,z;

x=y=2; z=3;

y=x++-1; printf("%d\t%d\t%d\t",x,y,z);

y=--z+1; printf("%d\t%d\t%d\n",x,y,z);

x=y=z=0; ++x&&++y||++z;

printf("%d\t%d\t%d\t",x,y,z);

--x&&++y&&++z;

printf("%d\t%d\t%d\n",x,y,z);

}

输出结果为:

6. 编程,输入长方形的长和宽,求长方形的面积和周长并输出。

7. 编程,输入3个字符后,按各字符ASCII码从小到大的顺序输出这些字符。给出

8. 编程,输入3个整数,要求按绝对值从小到大输出。

9. 编程,输入3个数,计算这三个数的平均值,并求出与平均值最接近的值。给出

#include

#include

void main()

{ float v,a,b,c,x;

scanf("%f%f%f",&a,&b,&c);

v=(a+b+c)/3;

x= fabs(v-a)< fabs(v-b) ? a:b;

x= fabs(v-c)< fabs(v-x) ? c:x;

printf("%f\n",x);

}

10. 编程,输入1个3位正整数,输出其个位、十位、百位反序的数(如123反序数为321)。

c语言试题及答案

1、以下正确的说法是( B ) (A) 用户若需要调用标准库函数,调用前必须重新定义 (B) 用户可以重新定义标准库函数,若如此,该函数将失去原有含义 (C) 系统根本不允许用户重新定义标准库函数 (D) 用户若需调用标准库函数,调用前不必使用预编译命令将该函数所在文件包括到用户源文件中,系统自动去调 2、以下正确的函数声明形式是( A ) (A) double fun(int x, int y) (B) double fun(int x; int y) (C) double fun(int x, int y); (D) double fun(int x,y); 3、以下正确的函数形式是( D ) (A) double fun(int x, int y) { z=x+y; return z;} (B) fun(int x,y) { int z; return z;} (C) fun(x,y) { int x,y; double z; z=x+y; return z;} (D) double fun(int x, int y) { double z; z=x+y; return z;} 4、以下正确的说法是( A ) 在C语言中 (A) 实参和与其对应的形参各占用独立的存储单元 (B) 实参和与其对应的形参共占用一个存储单元 (C) 只有当实参和与其对应的形参同名时才共占用存储单元 (D) 形参是虚拟的,不占用存储单元 5、若调用一个函数,且此函数中没有return语句,则正确的说法是( A ) 该函数 (A) 没有返回值 (B) 返回若干个系统默认值 (C) 能返回一个用户所希望的函数值 (D) 返回一个不确定的值 6、以下不正确的说法是( B ) C语言规定 (A) 实参可以是常量、变量和表达式 (B) 形参可以是常量、变量和表达式 (C) 实参可以为任意类型 (D) 形参应与其对应的实参类型一致 7、以下正确的说法是( C ) (A) 定义函数时,形参的类型说明可以放在函数体内 (B) return后边的值不能为表达式 (C) 如果函数值的类型与返回值类型不一致,以函数值类型为准 (D) 如果形参与实参的类型不一致,以实参类型为准 8、C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是( B ) (A) 地址传递 (B) 单向值传递 (C) 由实参传给形参,再由形参传回给实参 (D) 由用户指定传递方式

C语言常见复习题(选择填空)及参考答案

C语言常见复习题及参考答案 一、选择题 1.下述标识符中,()是合法的用户标识符。 A.A#C B.getch C.void D.ab* 2.在C语言中,字符型数据在内存中是以()形式存放的。 A.原码 B.BCD码 C.反码 D.ASCII码 3.以下选项中不合法的用户标识符是()。 A.abc.c B.file C.Main D.PRONTF 4.以下选项中不合法的用户标识符是()。 A.123 B.printf C.Anbsp; D.Dim 5.可以在C语言程序中用做用户标识符的一组标识符是()。 A.void B.as-b3 C.for D.2c define -123 -abc Do WORD If cas SIG 6.在以下各组标识符中,合法的用户标识符是(1)、(2)、(3)。 (1)A.001 B.table_1 C.0_t D.k% Int t*.1 W10 point (2)A.Fast_ B.void C.pbl D. Fast+Big abs fabs beep (3)A.xy_ B.longdouble C.*p D.CHAR 变量1 signed history Float 7.()是构成C语言的基本单位。 A.函数 B.过程 C.子程序 D.子例程 8.若有说明:char s1='\067';char s2="1";char s3='1';则s1中(1),s2中(2),s3中(3)。

(1).A.包含3个字符 B.包含2个字符 C.包含1个字符 D.无定值,说明不合法 (2).A.包含1个字符 B.包含2个字符 C.包含3个字符 D.无定值,说明不合法 (3).A.包含1个字符 B.包含2个字符 C.包含3个字符 D.无定值,说明不合法 9.若x为int型变量,则执行以下语句后,x的值为 x=6; x+=x-=x*x A.36 B.-60 C.60 D.-24 10.在C语言中,char 型数据在内存中是以()形式存储的。 A.原码 B.补码 C.ASCII码 D.反码 11.以下运算符中优先级最低的算符为(),优先级最高的为()。 A.&& B.& C.|= D.|| E.?: F.!= 12.若有运算符>、*=、<<、%、sizeof,则它们按优先级(由低至高)的正确排列顺序为 A.*= << > % sizeof B.<< *= > % sizeof C.*= > << sizeof % D.*= > << % sizeof 13.若有以下类型说明语句 char w; int x; float y; double z; 则表达式w*x+z-y 的结果是()类型。 A.float B.char C.int D.double 14.若w,x,y,z 均为int 型变量,则执行下面的语句后, w=(1), x=(2), y=(3), z=(4)。 w=5; x=4; y=w++*w++*w++; z=--x*=--x*--x;

c 试题及答案

一、单项选择题 1、下列哪个类型的对象是https://www.doczj.com/doc/1b10422941.html,在非连接模式下处理数据内容的主要对象? (D ) A. Command B. Connection C. DataAdapter D. DataSet 2、枚举类型是一组命名的常量集合,所有整形都可以作为枚举类型的基本类 型, 如果类型省略,则定义为( A )。 A. int B. sbyte C. uint D. ulong 3、创建数据库连接使用的对象是( A )。 A. Connection B. Command C. DataReader D. DataSet 4、C#中导入某一命名空间的关键字是( A )。 A. using B. use C.import D. include 5、一般情况下,异常类存放在什么命名空间中?( B )。 A. 生成异常类所在的命名空间 B. System.Exception命名空 间 C. System.Diagnostics命名空间 D. System命名空间 6、若将数据库中的数据填充到数据集,应调用SqlDataAdapter的( C )方 法。 A. Open B. Close C. Fill D. Update 7、若将数据集中所作更改更新回数据库,应调用SqlAdapter的(A )方法。 A. Update B. Close C. Fill D. Open 8、在使用FileStream 打开一个文件时,通过使用FileMode 枚举类型的( A ) 成员,来指定操作系统打开一个现有文件并把文件读写指针定位在 文件尾部。 A. Append B. Create C. CreateNew D. Truncate 9、在菜单项File中,为将F设为助记符,应将该菜单项的Text属性设置为 (B )。 A. @File B.&File C. %File D._File 10、指定操作系统读取文件方式中的FileMode .Create的含义是( D)。 A. 打开现有文件 B. 指定操作系统应创建文件,如果文件存在,将出现异常 C. 打开现有文件,若文件不存在,出现异常 D. 指定操作系统应创建文件,如果文件存在,将被改写 11、枚举类型是一组命名的常量集合,所有整形都可以作为枚举类型的基本类 型,如果类型省略,则定义为( D )。 A. uint B. sbyte C. ulong D. int 12、当运行程序时,系统自动执行启动窗体的( C )事件。 A. Click B.DoubleClick C. Load D. Activated

(完整版)C语言试题及答案解析

C语言 一、选择题(第题2分,共20分) 1.一个C程序的执行是从 A 。 A) 本程序的main函数开始,到main函数结束 B) 本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C) 本程序文件的第一个函数开始,到本程序main函数结束 D) 本程序的main函数开始,到本程序文件的最后一个函数结束 2.若x、i、j、k都是int型变量,则计算下面表达式后,x的值为 C 。 x=(i=4,j=16,k=32) A) 4 B) 16 C) 32 D) 52 3.设C语言中,一个int型数据在内存中占2个字节,则unsigned int 型数据的取值范围为 C 。 A) 0~255 B) 0~32767 C) 0~65535 D) 0~2147483647 4.设有说明:char w; int x; float y; double z;则表达式w*x+z-y值的数据类型为 D 。 A) float B) char C) int D) double 5. putchar函数可以向终端输出一个 D 。 A) 整型变量表达式 B) 实型变量值 C) 字符串 D) 字符或字符型变量值 6. printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列。如果字符串长度大于5,则输出按方式 B ;如果字符串长度小于5,则输出按方式 C 。 A) 从左起输出该字符串,右补空格 B) 按原字符长从左向右全部输出 C) 右对齐输出该字符串,左补空格 D) 输出错误信息 7.判断char型变量ch是否为大写字母的正确表达式是 C 。 A) ‘A’<=ch<=‘Z’ B) (ch>=‘A’)&(ch<=‘Z’) C) (ch>=‘A’)&&(ch<=‘Z’) D) (‘A’<= ch)AND(‘Z’>= ch) 8.已知int x=10,y=20,z=30;以下语句执行后x,y,z的值是 B 。 if(x>y) z=x; x=y; y=z; A) x=10, y=20, z=30 B) x=20, y=30, z=30 C) x=20, y=30, z=10 D) x=20, y=30, z=20 9.以下程序段______C__. x=-1; do{ x=x*x; } while(!x); A)是死循环 B)循环执行二次 C)循环执行一次 D)有语法错误 10.以下正确的描述是___B____. A)continue语句的作用是结束整个循环的执行

C语言练习题(带答案)

一、单项选择题 1.(A)是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 2.C语言程序从C开始执行。 A) 程序中第一条可执行语句B) 程序中第一个函数 C) 程序中的main函数D) 包含文件中的第一个函数 3、以下说法中正确的是(C)。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是(B )。 A) C程序的工作过程是编辑、编译、连接、运行 B) C语言不区分大小写。 C) C程序的三种基本结构是顺序、选择、循环 D) C程序从main函数开始执行 5.下列正确的标识符是(C)。 A.-a1 B.a[i] C.a2_i D.int t 6.下列C语言用户标识符中合法的是(B)。 A)3ax B)x C)case D)-e2 E)union 7.下列四组选项中,正确的C语言标识符是(C)。 A)%x B)a+b C)a123 D)123 8、下列四组字符串中都可以用作C语言程序中的标识符的是(A)。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# His.age 9.C语言中的简单数据类型包括(D)。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是C。 A)2.5 B)2 C)1 D)3 11.如果int a=3,b=4;则条件表达式"a

C期末考试题及答案

C期末考试题及答案 Revised at 2 pm on December 25, 2020.

一、填空题(每空0.5分,共30分) 1、世界坐标系简称__WCS_用户自定义坐标系简称__UCS_。 2、工作空间的切换:“工具”/“工作空间”或“工作空间”工具栏。 3、工具栏包括30种,系统默认的显示工具栏包括:“标准”、“属性”、“绘图”和“修改”等工具栏。 4、多线的对正方式有_上(T)_、_无(Z)_和_下(B)_。 5、文字标注包括标注单行文字和标注多行文字。 6、渲染环境是指在渲染对象时进行的雾化和深度设置。 7、漫游和飞行用户可以通过键盘和鼠标来控制视图显示,并创建导航动画。 8、编辑实体的边的种类:压印边、复制边、着色边。 9、动态块是通过自定义夹点或自定义特性定义的块。在图形中使用动态块,用户可以随时对组成块的对象进行修改。 10、三维实体是具有体积、质量、重心、回转半径、惯性距等特征的三维对象。 11、在AutoCAD 2007中,用户可以创建的光源有电光源、聚光灯光源和平行光光源。 12、相切、相切、半径法是指:通过指定圆的两个切点和半径来绘制圆。 13、绘制圆环的步骤中,先输入圆环的内径和外径,后确定圆环的中心点。 14、计算机辅助设计是:工程技术人员在CAD系统的辅助下,根据产品的设计程序进行设计的一项新技术。 15、菜单栏包括11种,每一种菜单中都含有四种显示情况:命令后跟右三角 、后跟省略号、后跟快捷键或功能键或命令呈灰色。 16、要对图形对象进行编辑就必须选中图形对象,在AutoCAD 2007中,选择对象的方法很多,常用的有_直接拾取_、矩形框选择_、_不规则区域选择_和快速选择。 17、在设置显示精度时,如果设置的精度越高,即分辨率就越高,计算机计算的时间 也越长,显示图形的速度也就越慢。 18、三维基本实体的种类包括:多段体、长方体、楔体、圆柱体、圆锥体、球体、圆环体、棱锥面。 19、布尔运算中只留重复的一部分的运算是交集运算。从一个图形中去掉与另一个图形重复部分的运算是差集运算。

c练习题(带答案)

一、选择题 1.C++语言属于( C )。 A)自然语言B)机器语言C)面向对象语言D)汇编语言2.下面选项中不属于面向对象程序设计特征的是(C) 。 A)继承性B)多态性C)相似性D)封装性 3.可用作C++语言用户标识符的一组标识符是( B )。 A)void define +WORD B)a3_b3 _123 YN C)for -abc Case D)2a DO sizeof 4.假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[2][1]的值为 (A)。 A)0 B)4 C)8 D)6 5.下列情况中,哪一种情况不会调用拷贝构造函数( B ) A)用派生类的对象去初始化基类对象时 B)将类的一个对象赋值给该类的另一个对象时 C)函数的形参是类的对象,调用函数进行形参和实参结合时 D)函数的返回值是类的对象,函数执行返回调用者时 6.以下哪一关键字可用于重载函数的区分(C) A)extern B)static C)const D)virtual 7.下列有关数组的叙述中,正确的是( B ) A)C++中数组的存储方式为列优先存储 B)数组名可以作为实参赋值给指针类型的形参 C)数组下标索引从1开始,至数组长度n结束 D)数组指针的语法形式为:类型名*数组名[下标表达式]; 8.下列有关继承和派生的叙述中,正确的是( C) A)派生类不能访问通过私有继承的基类的保护成员 B)多继承的虚基类不能够实例化 C)如果基类没有默认构造函数,派生类就应当声明带形参的构造函数 D)基类的析构函数和虚函数都不能够被继承,需要在派生类中重新实现 9.实现运行时多态的机制是( A ) A)虚函数B)重载函数C)静态函数D)模版函数 10.若有下面的函数调用:

c语言试题及答案

C语言部分 一、选择题(每小题2分,共10分) (下在各小题,分别有一个或多个正确答案,请将所有正确答案的编号,填写在该小题题干后的括号内。错选或漏选均不得分)。 1、若定义:int a[2][3]{0,2,4,6,8,10};以下描述正确的有( A,C,D, E ) A、*(a+1)为元素6的地址 这里a+1=a[1]的地址;*(a+1)的值是6,故A正确。 B、*(a[1]+1)的值为2 为8,故B不正确 C、**(a+1)+2的值为8 这里a+1是一个指针,指向的是a[1]. *(a+1)为a[1],a[1]指向的是a[1][0]. **(a+1)为6,加2得8,故C正确; D、a[0]与a相同 因二者都是指针,指针的地址都是指向数组中的第一个元素的地址,故D正确。 E、a[1][2]的值为10 它是指第二行的第三个元素,为10,正确 2、对函数的正确使用方法描述( A,C,D )。 A、用数组做函数参数时,必须在主调函数和被调函数中分别定义数组 B、实参数组元素和形参数组元素类型可以不一致 C、形参数组长度可以不指定 D、形参数组长度可以大于实参数组长度 E、数组名做参数属于值传递 3、对静态变量的正确描述( A,B,D,E )

A、静态局部变量在静态存储区内分配单元() B、静态外部变量可以赋初值,也可以不赋初值 C、静态外部变量的作用与外部变量相同 D、静态局部变量在函数调用结束时,仍保存其值,不会随着消失。 E、静态局部变量只赋一次初值 4、下列描述正确的是( A ,C)。 A、由main 函数及其参数argc和* argv[]可以实现命令行方式 B、使用fclose关闭文件时,先释放文件指针,再写缓冲区数据到文件中 //先写缓冲区数据到文件中,再释放文件指针 C、字符数组并不要求它的最后一个字符是‘\0’ //是的,以字符指针指向的字符串才要求,因为只有这样,才能知道字符串的长度,而在字符数组中,不用\0,一样可以知道到哪里是字符数组的结尾。 D、‘A’和“A”都是字符串常量 E、若char*S=“\ta\017bc”;则指针变量S指向的字符串所占的字节数是7 5、在缓冲文件系统中用于读写的函数有( A,B,D ) A、putchar () B、fread() C、rewind () D、purw() E、fseek() 二、程序阅读,并给出运行结果(共10分,每题5分)。 (1)main() { unsigned a,b,x int n; a=0x763 输出结果: n=6;

C语言试题及答案

第1章 C语言概述习题 1. 单项选择题 (1) C 语言是在 B 语言的基础上产生的。 A. A B. B C. D D. E (2) 在 C 语言中,每个语句必须以 D 结束。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (3) 标识符和关键字间,要用 C 隔开。 A. 回车符 B. 冒号 C. 空格 D. 分号 (4) 用 C 语言编写的源文件经过编译,若没有产生编译错误,则系统将( B )。 A. 生成可执行目标文件 B. 生成目标文件 C. 输出运行结果 D.自动保存源文件 (5) 下列说法中正确的是( B )。 A. 由于 C 源程序是高级语言程序,因此一定要在 TC 软件中输入 B. 由 C 源程序是字符流组成,因此可以作为文本文件在任何文本编辑的软件中输入 C. 由于C 程序是高级语言程序,因此输入后即可执行 D. 由于 C 程序是高级语言程序,因此它由命令组成 (6) 下列说法中正确的是( A )。 A. C 语言程序由主函数和 0 个或多个函数组成 B. C 语言程序由主程序和子程序组成 C. C 语言程序由子程序组成 D. C 语言程序由过程组成 (7) 下列说法中错误的是( D )。 A. 主函数可以分为两个部分:主函数说明部分和主函数体 B. 主函数可以调用任何非主函数的其他函数 C. 任何非主函数可以调用其他任何非主函数 D. 程序可以从任何非主函数开始执行 2. 填空题 (1) C 语言只有 32 个关键字和 9 种控制语句。 (2) C 语言是一种“中级语言”,既具有高级语言的特点又具有低级语言的特点;既适合于开发系统软件又适合于编写应用程序。 (3) 每个源程序有且只有一个主函数,系统总是从该函数开始执行C语言程序。 (4) 在 C 语言程序中允许出现的字符集是 ASCII码字符集。 (5) C 语言的程序中有特殊含义的英语单词称为保留字。 (6) C 语言标识符的长度是前 8 位有效。 (7) C 语言中,标识符的定义规则是以字母或下划线为开头。 (8) C 语言程序的注释可以出现在程序中的任何地方,它总是以 /* 符号作为开始标记,以 */ 符号作为结束标记。 第2章数据类型运算符和表达式习题 1. 单项选择题 (1) 以下选项中,正确的 C 语言整型常量是 D 。 A. 32L B. 510000 C. -1.00 D. 567 (2) 以下选项中, D 是不正确的 C 语言字符型常量。

c练习题带答案

c练习题带答案集团标准化工作小组 #Q8QGGQT-GX8G08Q8-

一、选择题 1.C++语言属于( C )。 A)自然语言 B)机器语言 C)面向对象语言 D)汇编语言2.下面选项中不属于面向对象程序设计特征的是(C) 。 A)继承性 B)多态性 C)相似性 D)封装性 3.可用作C++语言用户标识符的一组标识符是( B )。 A) void define +WORD B) a3_b3 _123 YN C) for -abc Case D) 2a DO sizeof 4.假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素 a[2][1]的值为(A)。 A) 0 B) 4 C) 8 D) 6 5.下列情况中,哪一种情况不会调用拷贝构造函数( B ) A)用派生类的对象去初始化基类对象时 B)将类的一个对象赋值给该类的另一个对象时 C)函数的形参是类的对象,调用函数进行形参和实参结合时 D)函数的返回值是类的对象,函数执行返回调用者时 6.以下哪一关键字可用于重载函数的区分(C) A)extern B)static C)const D)virtual 7.下列有关数组的叙述中,正确的是( B ) A)C++中数组的存储方式为列优先存储 B)数组名可以作为实参赋值给指针类型的形参 C)数组下标索引从1开始,至数组长度n结束 D)数组指针的语法形式为:类型名 *数组名[下标表达式]; 8.下列有关继承和派生的叙述中,正确的是( C ) A)派生类不能访问通过私有继承的基类的保护成员 B)多继承的虚基类不能够实例化 C)如果基类没有默认构造函数,派生类就应当声明带形参的构造函数 D)基类的析构函数和虚函数都不能够被继承,需要在派生类中重新实现 9.实现运行时多态的机制是( A ) A)虚函数B)重载函数C)静态函数D)模版函数 10.若有下面的函数调用: fun(a+b, 3, max(n-1, b)); 其中实参的个数是( A) A)3 B)4 C)5 D)6 11.下列关于this指针的说法正确的是( B)

C语言试题及答案

一、单项选择题 1. 软件危机具有下列表现( d )。 I. 对软件开发成本估计不准确II. 软件产品的质量往往靠不住 III. 软件常常不可维护IV. 软件成本逐年上升 A. I、II和III B. I、III和IV C. II、III和IV D. 以上都正确 2. 软件生命周期一般都被划分为若干个独立的阶段,其中占用精力和费用最多的阶段往往是( A )。 A. 运行和维护阶段 B. 设计阶段 C. 代码实现阶段 D. 测试阶段 3. 下列属于软件的特点的是(D )。 A. 软件是一种逻辑实体,具有抽象性 ~ B. 软件在使用过程中没有磨损、老化的问题 C. 软件不同于一般程序,它的一个显著特点是规模庞大,复杂程度高 D. 以上都正确 4. 软件工程的出现是由于(D )。 A. 软件危机的出现 B. 计算机硬件技术的发展 C. 软件社会化的需要 D. 计算机软件技术的发展 5. 软件开发技术不包含( d )。 A. 软件开发方法学 B. 软件工程环境 C. 软件工具 D. 软件质量度度量 6. 软件工程的课程特点( D )。 【 I. 学科理论及其知识应用的多维性 II. 工程化 III. 浓厚的方法学色彩 IV. 实践性、指导性强 A. I、II和III B. I、III和IV C. II、III和IV D. 以上都正确 7. 下列属于应用软件的是( b )。 I. 计算机辅助教学软件II. 软件测试工具 III. 办公自动化软件IV. 工程与科学计算软件

A. I、II和III B. I、III和IV C. II、III和IV D. 以上都正确 8. 需求分析阶段最重要的技术文档是( b )。 - A. 设计说明书 B. 需求规格说明书 C. 可行性分析报告 D. 用户手册 9. 以下关于数据流图的说法错误的是( c )。 A. 数据流图舍去了具体的物质,只剩下数据的流动、加工处理和存储 B. 数据流图是用作结构化分析的一种工具 C. 传统的数据流图中主要由加工、数据源点/终点、数据流、控制流、数据存储组成 D. 数据流图的绘制采用自上向下、逐层分解的方法 10. 数据字典是软件需求分析阶段的最重要工具之一,其最基本的功能是( c )。 A. 数据库设计 B. 数据通信 C. 数据定义 D. 数据维护 11. 需求分析阶段的研究对象是( b )。 ¥ A. 系统分析员要求 B. 用户要求 C. 软硬件要求 D. 系统要求 12. 结构化方法的基本原则是( b )。 A. 模块化 B. 抽象与分解 C. 信息隐蔽 D. 逐步求精 13. 耦合度最高的是(b)耦合。 A. 环境 B. 内容 C. 控制 D. 数据 14. 内聚程度较低的是( a )内聚。 A. 偶然 B. 通讯 C. 顺序 D. 时间 15. 对一个程序来说,组成系统的模块数目( b ),则开发成本越小。 A. 越多 B. 越少 C. 顺序 D. 时间> 16. 画软件结构图时应注意调用关系只能是(B )。 A. 从下到上 B. 从上到下 C. 从左到右 D. 从右到左 17. 程序流程图中的箭头代表( b )。 A. 数据流 B. 控制流 C. 顺序流 D. 调用 18. 软件测试是软件质量保证的重要手段,下述( B )是软件测试的最基础环节。

C详细答案复习题c

第3章运算符和表达式 丰富的运算符可使表达式方便、简捷。初学者一下掌握这么多操作符会有压力。可通过写或计算表达式的练习,以及各章程序实例中出现的表达式,进一步熟悉运算符。 3.1 表达式的基本概念 对数据进行各种运算的符号为运算符,参与运算的数据为操作数。表达式构成:常量、变量、有返回值的函数调用是表达式,表达式加圆括号、或用运算符作正确连接后也是表达式。 圆括号左、右括号个数要相同,多层括号时内层括号中的运算优先;整个表达式必须写在同一行上。 a·x3+b·x2+c·x+d 写作 a*x*x*x+b*x*x+c*x+d 或 ((a*x+b)*x+c)*x+d; 写作 1/(1+1/(1+x));等等。 C运算符:算术、关系、逻辑、条件、赋值、逗号运算符,等等。 根据参与运算的操作数个数,运算符可分为单目、双目以及三目运算符。两个操作数的运算符是双目运算符,“单目运算符”只有一个操作数。三目运算符是C语言所特有的,它有三个操作数。 不同运算符参与运算时有优先级问题。如先乘除、后加减。 同级运算一般是从左向右进行。特例如赋值“x=y=3”,先计算y=3、再计算x=y。特例将特别指出,一般按缺省。 主要介绍算术(包括自增自减)、关系、逻辑、赋值、逗号运算符,以及由这些运算符构成的各类表达式。 3.2 算术运算符与算术表达式 内容:算术运算符及其功能,算术表达式,优先级、运算时的类型转换规则。 3.2.1 算术运算符 1. 算术运算符 C的算术运算符有:+ - * / %(取余) 其中“-”可作单目运算符,如-5,表达式3*-5值为-15。 各运算符优先级:先乘除、后加减;取余的优先级和乘除相同。 优先级的讨论,应限于同一层括号内,同级运算一般从左到右执行。具体规则如下:

C语言试题库(带答案解析)~排版

一、选择题 1、以下不能定义为用户标识符的是( )。 (A) MAIN (B) _HJ (D) LINE1 2、以下不能定义为用户标识符的是( ) (A) If (B) H_J (D) LINE12 3、下面属于C 语言标识符的是( )。 (A) 2ab (B) @f (C) b 4、下列符号中用来表示C 语言中的回车换行的是( )。 (A) \r (C) \b (D) \t 5、在计算机系统中,可执行程序是( ) (A) 源代码 (B)汇编语言代码 (D) ASCII 码 6、在Visual C++ 环境下,C 源程序文件名的默认后缀是( )。 (A) .obj (B) .txt (D) .doc 7、Microsoft Visual C++ 中,C 语言可执行程序的扩展名是:( ) (B) obj (C) c 或cpp (D) txt 8、C 程序由( )组成。 (A)子程序 (B) 主程序和子程序 (D) 过程 9、C 程序的基本组成单位( )。 (A) 数据类型 (B) 变量和常量 (D) 表达式 10、C 语言中主函数的个数是( )。 (A) 2个 (C) 任意个 (D) 10个 11、一个 C 程序的执行是从( ) (B)本程序文件的第一个函数开始,到本程序文件最后一个函数结束. (C)本程序文件的第一个函数开始,到本程序main 函数结束. (D) 本程序的main()函数开始,到本程序文件的最后一个函数结束. 12、以下叙述正确的是 (A)在C 语言程序中,main 函数必须放在其他函数的最前面 (C)在C 语言程序中,只有main 函数才可单独进行编译 (D)每个后缀为.C 的C 语言源程序都应该包含一个main 函数 13、设变量a 是整型,b 是实型,c 是双精度型,则表达式2+’a’+b*c 值的数据类型是( )。 (A) int (B) float 14、以下选项中表示一个合法的常量是(说明:符号□表示空格) A) 9□9□9 C) D) 15、以下选项中非法的字符常量是 A)'\102' B)'\65' C)'\xff' 16、以下选项中,能表示逻辑值“假”的是 A)1 B) D) 17、下列关系表达式中,结果为“假”的是 A)(3+4)>6 C) 3<=4||3 D)(3<4)==1 18、关于C 语言变量,以下说法不正确的是( ) (A) 变量名由程序员定义,必须符合标识符的命名规则。 (B) 变量是程序运行过程中其值可以改变的量。 (D) 变量命名时应尽量做到见名知意。 19、关于C 语言中数的表示,以下叙述正确的是 B)只要在在允许范围内整型和实型都能精确表示 C)只有实型数在允许范围内能精确无误的表示,整型数会有误差 D)只有八进制表示的数在不会有误差 20、设有语句int a=3;,则执行了语句a+=a=a*a;后,变量a 的值是 。 A .3 B .0 C .9 21、在C 语言中,要求运算数必须是整型的运算符是 。 B ./ C .< D .! 22、C 语言中最简单的数据类型包括 。 A .整型、实型、逻辑型 C .整型、字符型、逻辑型 D .整型、实型、逻辑型、字符型 23 、在C 语言中,合法的字符型常量是 。 B ."A" C .65 D .A 24、若已定义x 和y 为double 型变量,则表达式x=1 ,y=x+3/2的值是 。 A .1 B .2 D . 25、设正x 、y 均为整型变量,且x=10,y=3,则以下语句的输出结果是 。 printf("%d,%d\n",x--,--y); A .10,3 B .9,3 C .9,2 26、若有定义int a=8,b=5,C;,执行语句C=a/b+;后,C 的值为 。 A . C . D .2 27、以下选项中,不正确的赋值语句是 。 A .++t; B .n1=(n2=(n3=0)); C .k=i==j; 28、设x 和y 均为 int 型变量,则语句:x+=y,y=x-y;x-=y;的功能是 。 A .把x 和y 按从大到小的顺序排列 B .把x 和y 按从小到大的顺序排列 C .无确定结果 29、以下程序的输出结果是 。 #include <> main() { char c='z'; printf("%c",c-25); } B .Z C .z-25 D .y 30、已知字母A 的ASCII 码为十进制数的65,以下程序的输出结果是 。 #include <> main() { char ch1,ch2; ch1='A'+'5'-'3'; ch2='A'+'6'-'3'; printf("%d,%c\n",ch1,ch2); B .B,C C .C,D D .不确定的值 31、若k 是int 型变量,则以下程序片段的输出结果是 。 k=-3; if(k<=0) printf("####"); printf("&&&&"); B .&&&& C .####&&&& D .有语法错误,无输出结果 32、关于以下程序,说法正确的是 。 #include <> main()

C试题及答案一

C++程序设计模拟试卷(一) 一、单项选择题(本大题共20小题,每小题1分,共20分)在每小题列出的四个备选项中 只有一个是符合题目要求的,请将其代码填写在题后的括号内。错选、多选或未选均无 分。 1. 编写C++程序一般需经过的几个步骤依次是() A. 编辑、调试、编译、连接 B. 编辑、编译、连接、运行 C. 编译、调试、编辑、连接 D. 编译、编辑、连接、运行 答案:B 解析:经过编辑、编译、连接和运行四个步骤。编辑是将C++源程序输入计算机的过程,保 存文件名为cpp。编译是使用系统提供的编译器将源程序cpp生成机器语言的过程,目标文件为 obj,由于没有得到系统分配的绝对地址,还不能直接运行。连接是将目标文件obj转换为可执行 程序的过程,结果为exe。运行是执行exe,在屏幕上显示结果的过程。 2. 决定C++语言中函数的返回值类型的是() A. return语句中的表达式类型 B. 调用该函数时系统随机产生的类型 C. 调用该函数时的主调用函数类型 D. 在定义该函数时所指定的数据类型 答案:D 解析:函数的返回值类型由定义函数时的指定的数据类型决定的。A项的表达式的值要转换 成函数的定义时的返回类型。 3. 下面叙述不正确的是() A. 派生类一般都用公有派生 B. 对基类成员的访问必须是无二义性的 C. 赋值兼容规则也适用于多重继承的组合 D. 基类的公有成员在派生类中仍然是公有的 答案:D 解析:继承方式有三种:公有、私有和保护。多继承中,多个基类具有同名成员,在它们 的子类中访问这些成员,就产生了二义性,但进行访问时,不能存在二义性。赋值兼容规则是指 派生类对象可以当作基类对象使用,只要存在继承关系,所以单继承或多继承都适用。基类中的 公有成员采用私有继承时,在派生类中变成了私有成员,所以D项错误。 4. 所谓数据封装就是将一组数据和与这组数据有关操作组装在一起,形成一个实体,这实体 也就是() A. 类 B. 对象 C. 函数体 D. 数据块 答案:A 解析:类即数据和操作的组合体,数据是类的静态特征,操作是类具有的动作。 5. 在公有派生类的成员函数不能直接访问基类中继承来的某个成员,则该成员一定是基类中 的() A. 私有成员 B. 公有成员 C. 保护成员 D. 保护成员或私有成员 答案:A 解析:在派生类中基类的保护或者基类公有都可以直接访问,基类的私有成员只能是基类 的成员函数来访问。所以选择A项。 6. 对基类和派生类的关系描述中,错误的是() A. 派生类是基类的具体化 B. 基类继承了派生类的属性 C. 派生类是基类定义的延续 D. 派生类是基类的特殊化 答案:B 解析:派生类的成员一个是来自基类,一个来自本身,所以派生类是基类的扩展,也是基 类的具体化和特殊化,派生类是对基类扩展。B项基类不能继承派生类成员,所以错误。 7. 关于this指针使用说法正确的是() A. 保证每个对象拥有自己的数据成员,但共享处理这些数据的代码

C语言试题及答案

C语言试题及答案 Company number【1089WT-1898YT-1W8CB-9UUT-92108】

第1章C语言概述习题1. 单项选择题 (1) C 语言是在 B 语言的基础上产生的。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (2) 在 C 语言中,每个语句必须以 D 结束。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (3) 标识符和关键字间,要用 C 隔开。 A. 回车符 B. 冒号 C. 空格 D. 分号 (4) 用 C 语言编写的源文件经过编译,若没有产生编译错误,则系统将( B )。 A. 生成可执行目标文件 B. 生成目标文件 C. 输出运行结果 D.自动保存源文件 (5) 下列说法中正确的是( B )。 A. 由于 C 源程序是高级语言程序,因此一定要在 TC 软件中输入 B. 由 C 源程序是字符流组成,因此可以作为文本文件在任何文本编辑的软件中输入 C. 由于C 程序是高级语言程序,因此输入后即可执行 D. 由于 C 程序是高级语言程序,因此它由命令组成 (6) 下列说法中正确的是( A )。 A. C 语言程序由主函数和 0 个或多个函数组成 B. C 语言程序由主程序和子程序组成

C. C 语言程序由子程序组成 D. C 语言程序由过程组成 (7) 下列说法中错误的是( D )。 A. 主函数可以分为两个部分:主函数说明部分和主函数体 B. 主函数可以调用任何非主函数的其他函数 C. 任何非主函数可以调用其他任何非主函数 D. 程序可以从任何非主函数开始执行 2. 填空题 (1) C 语言只有 37 个关键字和 9 种控制语句。 (2) C 语言是一种“中级语言”,既具有高级语言的特点又具有低级语言 的特点;既适合于开发系统软件又适合于编写应用程序。 (3) 每个源程序有且只有一个主函数,系统总是从该函数开始执行C语言程序。 (4) 在 C 语言程序中允许出现的字符集是 ASCII码字符集。 (5) C 语言的程序中有特殊含义的英语单词称为保留字。 (6) C 语言标识符的长度是前 8 位有效。 (7) C 语言中,标识符的定义规则是以字母或下划线为开头。 (8) C 语言程序的注释可以出现在程序中的任何地方,它总是以 /* 符号作为开始标记,以 */ 符号作为结束标记。

C考试复习题及答案

一、选择题 (1)下面关于类和对象的描述中,错误的是 A)类就是C语言中的结构体类型,对象就是C语言中的结构体变量 B)类和对象之间的关系是抽象和具体的关系 C)对象是类的实例,一个对象必须属于一个已知的类 D)类是具有共同行为的若干对象的统一描述体 (2)以下各选项组中,均是C++语言关键字的组是 A) public operator this B)shod string static C)it while >= D)private cout printf (3)在C++语言中,数据封装要解决的问题是 A)数据的规范化B)便于数据转换 C)避免数据丢失D)防止不同模块之间数据的非法访问 (4)以下程序中,错误的行是 ①#include ②class A ③{ ④ public: ⑤ int n=2: ⑥ A( int val){cout< class A { int num; public: A(int i){num=i;} A(A &a){num=a. num++;} void print(){cout<

C语言面试题及答案

1、局部变量能否和全局变量重名? 答:能,局部会屏蔽全局。要用全局变量,需要使用"::" 局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内。 2、如何引用一个已经定义过的全局变量? 答:extern 可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个变写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。 3、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么? 答:可以,在不同的C文件中以static形式来声明同名全局变量。 可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错 4、语句for( ;1 ;)有什么问题?它是什么意思? 答:和while(1)相同。 5、do……whi le和while……do有什么区别? 答:前一个循环一遍再判断,后一个判断以后再循环 6、请写出下列代码的输出内容 以下是引用片段: #include main() { int a,b,c,d; a=10; b=a++; c=++a; d=10*a++; printf("b,c,d:%d,%d,%d",b,c,d); return 0; }

答:10,12,120 7、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别? 全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量。全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。这两者在存储方式上并无不同。这两者的区别虽在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。而静态全局变量则限制了其作用域,即只在定义该变量的源文件内有效,在同一源程序的其它源文件中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用,因此可以避免在其它源文件中引起错误。 从以上分析可以看出,把局部变量改变为静态变量后是改变了它的存储方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的作用域,限制了它的使用范围。 static函数与普通函数作用域不同。仅在本文件。只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义。对于可在当前源文件以外使用的函数,应该在一个头文件中说明,要使用这些函数的源文件要包含这个头文件 static全局变量与普通的全局变量有什么区别:static全局变量只初使化一次,防止在其他文件单元中被引用; static局部变量和普通局部变量有什么区别:static局部变量只被初始化一次,下一次依据上一次结果值; static函数与普通函数有什么区别:static函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝 8、程序的局部变量存在于(堆栈)中,全局变量存在于(静态区)中,动态申请数据存在于( 堆)中。 9、设有以下说明和定义: typedef union {long i; int k[5]; char c;} DATE; struct data { int cat; DATE cow; double dog;} too; DATE max; 则语句printf("%d",sizeof(struct date)+sizeof(max));的执行结果是:___52____ 答:DATE是一个union, 变量公用空间. 里面最大的变量类型是int[5], 占用20个字节. 所以它的大小是20 data是一个struct, 每个变量分开占用空间. 依次为int4 + DATE20 + double8 = 32.

相关主题
文本预览
相关文档 最新文档