有数学式子 则不正确的C语言表达式是,C语言基础练习题

《C语言基础练习题》由会员分享,可在线阅读,更多相关《C语言基础练习题(50页珍藏版)》请在人人文库网上搜索。

1、第一章 C语言基础知识11 选择题1. 以下不是C语言的特点的是( )。A、语言简洁紧凑 B、能够编制出功能复杂的程序 C、C语言可以直接对硬件操作 D、C语言移植性好2. 下列字符序列中,不可用作C语言标识符的是( )。Aabc123 Bno.1 C_123_ D_ok 3. 正确的C语言标识符是 ( )。A_buy_2 B2_buy C?_buy Dbuy?4. 请选出可用作C语言用户标识符的一组标识符( )。 Avoid Ba3_b3 CFor D2adefine _123 -abc DOWORD IF Case sizeof5. 下列符号中,不属于转义字符的是( )。 A B0xAA 。

2、Ct D06. 不属于C语言关键字的是( )。 Aint Bbreak Cwhile Dcharacter 7. 是C语言提供的合法关键字的是( )。 AFloat Bsigned Cinteger DChar8. 以下不能定义为用户标示符的是( )。 Ascanf BVoid C_3com_ Dint 9. 一个C程序是由( )。 A 一个主程序和若干子程序组成B 一个或多个函数组成C 若干过程组成D 若干子程序组成10. C语言程序的基本单位是( )。 A程序行 B语句 C函数 D字符11. 下列说法中,错误的是( )。 A每个语句必须独占一行,语句的最后可以是一个分号,也可以是一个回车换。

3、行符号B每个函数都有一个函数头和一个函数体,主函数也不例外C主函数只能调用用户函数或系统函数,用户函数可以相互调用D程序是由若干个函数组成的,但是必须有、而且只能有一个主函数12. 以下说法中正确的是( )。 AC语言程序总是从第一个定义的函数开始执行B在C语言程序中,要调用的函数必须在main( )函数中定义CC语言程序总是从main( )函数开始执行DC语言程序中的main( )函数必须放在程序的开始部分13. C编译程序是( )。 AC程序的机器语言版本 B一组机器语言指令 C将C源程序编译成目标程序 D由制造厂家提供的一套应用软件14以下选项中,合法的用户标识符是( )。Along B。

4、_2abc C3dmax DA.dat15以下选项中,合法的实型常数是( )。A5E2.0 BE-3 C2E0 D1.3E16已知大写字母A的ASCII码值是65, 小写字母a的ASCII码是97,则用八进制表示的字符常量101是( )。A字符A B字符a C字符c D非法的常量17以下选项中, 合法转义字符的选项是( )。A B018 Cxab Dabc18以下选项中,正确的字符常量是( )。A”F” B CW D19以下选项中可作为C语言合法整数的是A10110B B0386 C0Xffa Dx2a220下列变量定义中合法的是 Ashort _a=1-.le-1; Bdouble b=1+。

5、5e2.5; Clong do=0xfdaL; Dfloat 2_and=1-e-3;21与数学式子对应的C语言表达式是( )。A9*xn/(2*x-1) B9*x*n/(2*x-1)C9*pow(x,n)*(1/(2*x-1) D9*pow(n,x)/(2*x-1)22若有代数式,则不正确的C语言表达式是( )。Aa/c/d*b*3 B3*a*b/c/dC3*a*b/c*d Da*b/d/c*323已知各变量的类型说明如下:int m=8,n, a, b;unsigned long w=10;double x=3.14, y=0.12;则以下符合C语言语法的表达式是( )。Aa+=a-=(b。

6、=2)*(a=8) B n=n*3=18Cx%3 Dy=float (m)24以下符合C语言语法的赋值表达式是( )。Aa=9+b+c=d+9 Ba=(9+b, c=d+9)Ca=9+b, b+, c+9 Da=9+b+=c+925 已知字母A的ASCII码为十进制数65,且S为字符型,则执行语句S=A+6-3;后,S中的值为( )。AD B68 C不确定的值 DC26在C语言中,要求运算数必须是整型的运算符是( )。A/ B+ C*= D%27若有说明语句:char s=72;则变量s( )。A包含一个字符 B包含两个字符C包含三个字符 D说明不合法,s的值不确定28若有定义:int m=7。

7、; float x=2.5, y=4.7; 则表达式x+m%3*(int)(x+y)%2/4的值是( )。A2. B2. C3. D0.29在C语言中,char型数据在内存中的存储形式是( )。A补码 B反码 C原码 DASCII码30设变量x为float类型,m为int类型,则以下能实现将x中的数值保留小数点后两位,第三位进行四舍五入运算的表达式是( )。Ax=(x*100+0.5)/100.0 Bm=x*100+0.5, x=m/100.0Cx=x*100+0.5/100.0 Dx=(x/100+0.5)*100.031表达式13/3*sqrt(16.0)/8的数据类型是( )。Aint 。

8、Bfloat Cdouble D不确定32设以下变量均为int类型,则值不等于7的表达式是( )。A(m=n=6, m+n, m+1) B(m=n=6, m+n, n+1)C(m=6, m+1, n=6, m+n) D(m=6, m+1, n=m, n+1)33假设所有变量均为整型,则表达式(x=2, y=5, y+, x+y)的值是( )。A7 B8 C6 D234已知s是字符型变量,下面不正确的赋值语句是( )。As=012; Bs= u+v;Cs=1+2; Ds=1+2;35已知s是字符型变量,下面正确的赋值语句是( )。As=abc; Bs=08;Cs=xde; Ds=”;36若有以下。

9、定义,则正确的赋值语句是( )。int x,y; float z;Ax=1,y=2, Bx=y=100 Cx+; Dx=int (z);37设x、y均为float型变量,则不正确的赋值语句是( )。A+x ; Bx*=y-2; Cy=(x%3)/10; Dx=y=0;38下列语句中符合C语言的赋值语句是( )。Aa=7+b+c=a+7; Ba=7+b+=a+7;Ca=7+b,b+,a+7 Da=7+b,c=a+7;39putchar函数可以向终端输出一个( )。A整型变量表达式值。 B字符串C实型变量值。 D字符或字符型变量值。40以下程序段的输出结果是( )。int a=12345; pri。

10、ntf(”%2dn”, a); A12 B34 C12345 D提示出错、无结果41若x和y均定义为int 型,z定义为double型,以下不合法的scanf()函数调用语句为( )。Ascanf(”%d%lx,%le”,&x,&y,&z);Bscanf (”%2d*%d%lf ”, &x, &y, &z);Cscanf(”%x%*d%o”, &x,&y);D。scanf(”%x%o%6.2f”, &x,&y,&z);42有如下程序段:int x1,x2;char y1,y2;scanf(”%d%c%d%c”,&x1,&y1,&x2,&y2);若要求x1、x2、y1、y2的值分别为10、20、。

11、A、B,正确的数据输入是( )。(注:代表空格)A10A20B B10A20BC10 A20 B D10A20B43若变量已正确说明为float类型, 要通过语句scanf(”%f %f%f”, &a, &b, &c);给a赋予10.0, b赋予22.0, c赋予33.0, 不正确的输入形式为( )。A10 B10.0,22.0,33.022 33C10.0 D10 2222.0 33.0 3344有如下程序,若要求x1、x2、y1、y2的值分别为10、20、A、B,正确的数据输入是( )。(注:代表空格)int x1,x2;char y1,y2;scanf(”%d%d”,&x1,&x2);s。

12、canf(”%c%c”, &y1,&y2);A1020AB B1020ABCC1020 D1020ABAB45已有定义int a=-2;和输出语句:printf(”%8lx”,a);以下正确的叙述是( )。A整型变量的输出格式符只有%d一种B%x是格式符的一种,它可以适用于任何一种类型的数据C%x是格式符D%8lx不是错误的格式符,其中数字8规定了输出字段的宽度46有如下程序段,对应正确的数据输入是( )。float x,y;scanf(”%f%f”, &x,&y);printf(”a=%f,b=%f”, x,y);A2.04 B2.04,5.67 5.67CA=2.04,B=5.67 D2.。

13、055.6747有如下程序段,从键盘输入数据的正确形式应是( )。(注:代表空格)float x,y,z;scanf(“x=%d,y=%d,z=%d”,&a,&y,&z);A123 Bx=1,y=2,z=3C1,2,3 Dx=1 y=2 z=348以下说法正确的是( )。A输入项可以为一个实型常量,如scanf(”%f”,3.5);B只有格式控制,没有输入项,也能进行正确输入,如scanf(”a=%d,b=5d”);C当输入一个实型数据时,格式控制部分应规定小数点后的位数,如scanf(”%4.2f”,&f);D当输入数据时,必须指明变量的地址,如scanf(”%f”,&f);49根据定义和数。

14、据的输入方式,输入语句的正确形式为:( )。(注:代表空格)已有定义:float x,y;数据的输入方式:1.234.5Ascan(”%f,%f”,&x,&y); Bscanf(”%f%f”,&x,&y);Cscanf(”%3.2f%2.1f”,&x,&y); Dscanf(”%3.2f%2.1f”,&x,&y);50根据下面的程序及数据的输入和输出形式,程序中输入语句的正确形式应该为( )。#include ”stdio.h”main()char s1,s2,s3;输入语句;printf(”%c%c%c”,s1,s2,s3);输入形式:ABC (注:代表空格)输出形式:ABAscanf(”%。

15、c%c%c”,&s1,&s2,&s3);Bscanf(”%c%c%c”,&s1, &s2,&s3);Cscanf(”%c,%c,%c”,&s1,&s2,&s3); Dscanf(”%c%c”, &s1, &s2,&s3);51以下程序的执行结果是:( )。#include ”stdio.h”main() int x=2,y=3;printf(”x=%d,y=%dn”,x,y);A. x=%2,y=%3 B. x=%d,y=%dC. x=2,y=3 D. x=%d,y=%d52以下程序的输出结果是( )。(注:代表空格)#include ”stdio.h”main() printf(”nstri。

16、ng1=%15s*”, ”programming”);printf(”nstring2=%-5s*”, ”boy”);printf(”string3=%2s*”, ”girl”);Astring1=programming* Bstring1=programming*string2=boy* string2=boy*string3=gi*string3=gi* Cstring1=programming* Dstring1=programming*string2=boy*string3=girl* string2=boy*string3=girl*53根据题目中已给出的数据的输入和输出形式,程序中。

17、输入输出语句的正确内容是( )。#include ”stdio.h”main() int a; float b;输入语句输出语句输入形式:12.3 (注:代表空格)输出形式:a+b=3.300Ascanf(”%d%f”,&a,&b); Bscanf(”%d%3.1f”,&a,&b);printf(”na+b=%5.3f”,a+b); printf(”na+b=%f”,a+b);Cscanf(”%d,%f”,&a,&b); Dscanf(”%d%f”,&a,&b);printf(”na+b=%5.3f”,a+b) printf(”na+b=%f”,a+b);54阅读以下程序,当输入数据的形式为:。

18、12,34,正确的输出结果为( )。#include ”stdio.h”main() int a,b;scanf(”%d%d”, &a,&b);printf(”a+b=%dn”,a+b);Aa+b=46 B有语法错误Ca+b=12 D不确定值55若有定义:int x,y; char s1,s2,s3; 并有以下输出数据:(注:代表空格)12UVW则能给x赋给整数1,给y赋给整数2,给s1赋给字符U,给s2赋给字符V,给s3赋给字符W的正确程序段是( )。Ascanf(”x=%dy=%d”,&x,&y); s1=getchar();s2=getchar();s3=getchar();Bscanf。

19、(”%d%d”,&x,&y); s1=getchar();s2=getchar();s3=getchar();Cscanf(”%d%d%c%c%c”,&x,&y,&s1,&s2,&s3);Dscanf(”%d%d%c%c%c%c%c%c”,&x,&y,&s1,&s1,&s2,&s2,&s3,&s3);12 填空题1 C语言的符号集包括________、________、________。2 结构化设计中的三种基本结构是________、_______、________。3 C语言源程序文件的后缀是________,经过编译后生成文件的后缀是________,经过链接后生成文件的后缀是_____。

20、___。4 C语言的关键字都用________大写或小写。5 一个函数由两部分组成,它们是_______、_______。6 函数体一般包括_______、_______。7 C语言是通过_______来进行输入和输出的。8 以下程序的执行结果________。#include ”stdio.h”main() short i=-1,j=1;printf(”dec:%d,oct:%o,hex:%x,unsigned:%un”,i,i,i,i);printf(”dec:%d,oct:%o,hex:%x,unsigned:%un”,j,j,j,j);9 以下程序的执行结果是________。#inc。

21、lude ”stdio.h”main() char s=b;printf(”dec:%d,oct:%o,hex:%x,ASCII:%cn”, s,s,s,s);10以下程序的执行结果是________。(注:代表空格)#include ”stdio.h”main() float pi=3.;printf(”%f,%.4f,%4.3f,%10.3f”,pi,pi,pi,pi);printf(”n%e,%.4e,%4.3e,%10.3e”,pi,pi,pi,pi);11以下程序的执行结果是:________。#include ”stdio.h”main() char c=c+5;printf(”c。

22、=%cn”,c);12以下程序输入123后的执行结果是________。(注:代表空格)#include ”stdio.h”main() int i,j;char k;scanf(”%d%c%d”,&i,&k,&j);printf(”i=%d,k=%c,j=%dn”,i,k,j);13有以下程序,若输入后的执行结果是________;若输入为:9876后的执行结果是________;若输入为:3210后的执行结果为:________。(注:代表空格)#include ”stdio.h”main() int x1,x2;char y1,y2;scanf(”%2d%3d%3c%c”,&x1,&x2。

23、,&y1,&y2);printf(”x1=%d,x2=%d,y1=%c,y2=%cn”,x,y);14若x和y均为int型变量,则以下语句的功能是________。x+=y; y=x-y; x-=y;15有一输入函数scanf(”%d”,k);则不能使float类型变量k得到正确数值的原因是:________。16有如下程序段,输入数据:12345ffl678后,u的值是 【1】 ,v的值是 【2】 。int u;float v;scanf(“%3d%f”,&u,&v);13 答案及部分解析一 选择题答案1B2B3A4B5B6D7B8D9B10C11A12C13C14B15C16A17A18C。

24、19C20A21C22C23A24B25A26D27A28A29D30B 31C32C33B34B35C36C 37C38D39D40C41D42A43B44D45D46A47B48D 49B50A51D52D53A54D 55D 14解析:C语言规定标识符只能由字母、数字和下划线三种字符组成,且第一个字符必须为字母或下划线。而且不能与C语言规定的关键字同名。关键字如:auto, break, case, char, const, continue, default, do, double, else, entry, extern, for, float, goto, if, int, int。

25、, long, register, return, short, signed, sizeof, static, struct, unsigned, while, switch, typedef, void, volatile, unior。这些关键字先不必硬背下来,随着后续的学习,你将发现它们都是一些数据的类型、语句等,自然会随着学习的深入,而记下来。15解析:用指数形式表示一个实型常数时,E或e之前必须有数字,且E后面指数必须为整数。16解析:101为转义字符,相对应一个ASCII码字符。(101)8=(65)10=A.17解析:转义字符的特征是以“”开头,其后跟一些字符,如n, t, ,。

26、 , , ”, b, f等代表一些特殊的含义,而后如跟数字,可以为八进制或者十六进制,将其转换为对应的ASCII码值,就可以得出对应的字符。“”后跟八进制的写法:0nn, 或者nn, 表示“0”或者“”后只能跟1或3位07之间的数字;“”后跟十六进制的写法:xnn,或者nn, 表示“x”或者“”后只能跟1或2位09及af(AF)之间的字符。选项B的错误在于8不是八进制;而选项C的错误在于没有“”;选项D的错误在于超长(多了一位)。21解析:B的错误在于赋值语句的左侧只能为一个简单变量,如:n=3*(n=18); C的错误在于%运算符只能适用于整型数据,D的错误在于作类型转换时,应将类型加上括号。

27、,即为:y=(float) m31解析:逗号表达式的最终结果为最右端的表达式(即x+y)的值,其运算顺序是从左自右的。第三个表达式y+,其隐含有两步操作:先取y的原值,再执行y=y+1运算;而本题中,虽然没有将y赋给某个变量(取其原值),但还是一定会执行加运算的。因而,经过第三个表达式,y已经自加为6,故x+y的值为8,相对应得表达式最终结果为8。若本题改为:(x=2, y=5, z=y+, x+z),则其结果应为7。二 填空题答案1 答案:英文字母、数字、一些有特定含义的标点符号2 答案:顺序结构、选择结构、循环结构3 答案:C,OBJ,EXE4 答案:小写5 答案:函数说明部分和函数体6 。

28、答案:变量定义部分和执行部分7 答案:输入和输出函数8 答案:dec:-1,oct:,hex:ffff,unsigned:65535dec:1,oct:1,hex:1,unsigned:19 答案:dec:98,oct:142,hex:62,ASCII:b10答案:3.,3.1416,3.142, 3.1423.e+00,3.1416e+00,3.142e+00,3.142e+00(注:由于c编译系统不同,我们上机使用的机器,其第二个printf语句实际结果为:3.14159e+00,3.142e+00,3.14e+00,3.14e+00,即:小数点后取5位。)11答案:c=h12答案:i=1。

29、,k=,j=213答案:第一种情况的执行结果:x1=98,x2=765,y1=4,y2=1第二种情况的执行结果:x1=98,x2=76,y1=,y2=3第三种情况的执行结果:x1=98,x2=765,y1=4,y2=214答案:交换x和y的值15答案:(1)格式符应为:%f;(2)变量前边未加取地址符&, 即应为scanf(”%f”,&k);16答案:【1】123 【2】45.第二章 选择结构21 选择题1 已有定义:int x=3, y=4, z=5; 则表达式!(x+y)+z-1 & y+z/2的值是()。A6 B0 C2 D12 设a=5,b=6,c=7,d=8,m=2,n=2, 则执行。

30、(m=ab) & (n=cd)后n的值为()。A1 B2 C3 D43 设x、y和z都是int类型变量,且x=3,y=4,z=5, 则下面的表达式中,值为0的表达式为()。Ax & y Bxb) c+;Dif(a=b) c+;9 能正确表示“当x的取值在-58,-40和40,58范围内为真,否则为假”的表达式是()。A(x= -58) & (x=40) & (x= -58) | (x=40) | (x= -58) & (x=40) & (x= -58) | |(x=40) | (x=a) & (s=a) & (s=s)11若希望当x的值为奇数时,表达式的值为“真”,x的值为偶数时,表达式的值为。

31、“假”。则以下不能满足要求的表达式是()。Ax%2=1 B!(x%2=0)C!(x%2) Dx%212已知 x=45, y=a, z=0; 则表达式(x=z & y0) y=1;else if (x=0) y=0;else y= -1;By=0;if (x0) y=1;else if (x=0)if(x0) y=1;else y= -1;Dif (x=0)if (x0) y=1;else y=0;else y= -1;15执行以下语句后,y 的值为()。int x,y,z;x=y=z=0;+x | +y & +z;A0 B1 C2 D不确定值16已知int a=1,b=2,c=3; 以下语句执。

32、行后a,b,c的值是()。if(ab)c=a; a=b; b=c;Aa=1, b=2, c=3 Ba=2, b=3, c=3Ca=2, b=3, c=1 Da=2, b=3, c=217请阅读以下程序:该程序()。#include ”stdioh”main() int x=-10, y=5, z=0;if (x=y+z) printf(”*n” );else printf(”$n”);A有语法错不能通过编译 B可以通过编译但不能通过连接C输出* D输出$18以下程序的运行结果是()。#include ”stdio.h”main() int a=1;if (a+1) printf(”%dn”, 。

33、a);else printf(”%dn”, a-);A0 B1 C2 D319当a=1,b=2,c=4,d=3时,执行完下面一段程序后x的值是()。if (ab? ac?a:c :b);A5 B4 C6 D不确定23若a、b、c1、c2、x、y均为整型变量,正确的switch 语句是()。Aswitch (a+b); Bswitch a case 1: y=a+b; break; case c1: y=a-b; break;case 0: y=a-b; case c2: x=a*d; break;break; default: x=a+b; Cswitch (a*a+b*b) Dswitch(。

34、a-b) case 3: default: y=a*b; break;case 1: y=a+b; break; case 3: x=a+b; break;case 3: y=b-a; break; case 10: case 11: y=a-b; break; 24执行下列程序,输入为3的数出结果是()。#include ”stdio.h”main() int k;scanf(”%d”, &k);switch(k) case 1: printf(”%dn”, k+);case 2: printf(”%dn”, k+);case 3: printf(”%dn”, k+);case 4: pri。

35、ntf(”%dn”, k+);break;default: printf(”Full!n”);A3 B4 C3 D45 425假定等级和分数有以下对应关系:等级:A 分数:85100等级:B 分数:6084等级:C 分数:60以下对于等级grade输出相应的分数区间,能够完成该功能的程序段是()。Aswitch (grade) case A :printf(”85100n”);case B :printf(”6084n”);case C :printf(”50) printf(”%d”, a);if (a40) printf(”%d”,a);if (a30) printf(”%d”,a);2 。

36、设int x=9,y=8;表达式x=y+1的结果是________。3 定义int x,y;执行y=(x=1,+x,x+2);后, y的值是________。4 定义int x=10,y,z; 执行y=z=x; x=y=z;后, x的结果是________。5 设int a=1,b=2,c,d,e; 执行c=(-a+)+(+b);d=(b-)+(+a)-a; e=(a/(+b)-(a/(-a);请问a,b,c,d,e的结果是:________。6 设int a=2,b=3,c,d,e,f; 执行c=(a+= -b);d=(a=+b);e=(a-!=b);f=(+ab-);请问a,b,c,d,e。

37、,f的结果是:________。7 以下程序的运行结果是________。#include ”stdio.h”main() int a,b,c,s,w,t;s=w=t=0;a= -1; b=3; c=3;if (c0) s=a+b;if (a0)if (c0) w=a-b;else t=c;printf(”%d %d %d”, s,w,t);8 以下程序的运行结果是________。#include ”stdio.h”main() int a,b,c,d,e;a=c=1;b=20;d=100;if (!a) d=d+;else if (!b)if (d) d= -d;else d= d-;printf(”%dnn”, d);9 以下程序的运行结果是________。#include ”stdio.h”main() int a, b= 250, c;if (c。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值