1、第二章:C语言概述1.如下()是不正确的转义字符。A. B. C.020 D.02.组成C语言程序的基本单位是()。A.函数B.变量C.子程序D.语句3.C语言要求:在一个源程序中,main( )函数的位置(C)。A.必须在最开始 B.必须在系统调用的库函数背面C.能够任意 D.必须在最后4.为求出return语句返回计算100!的成果,此函数的类型阐明应为(D)。A.int B.long C.unsigned long D.选项A,B,C.都不对:ABC的数值范围都不够5.C语言中的标识符只能由字母、数字和下划线3种字符组成,且第一个字符(C)。A.必须为字母B.必须为下划线C.必须为字母或
2、下划线D.能够是字母、数字和下划线中的任意一个6.如下选项中合法的用户标识符是(D)。A.int B.a# C.5mem D._2437.C语言中的简单数据类型有(C)。A.整型、实型、逻辑型 B.整型、字符型、逻辑型C.整型、实型、字符型 D.整型、实型、字符型、逻辑型8.如下选项中不正确的整型常量是(B)。A.-37 B.32,758 C.326 D.69.如下选项中合法的C语言字符常量是(A)。A.t B.A C.67 D. A10.如下选项中不正确的实型常量是(A)。A.123 B.1e4 C.3.640E-1 D.0.3511.如下选项中合法的C语言赋值语句是(D)。A.a=b=34
3、 B.a=34,b=34 C.-i; D.m=(int)(x+y);12.设int类型的数据长度为两个字节,则unsigned int类型数据的取值范围是(B)。A.0255 B.065535 C.-3276832767 D.-256255第三章:运算符与体现式 (原先给的答案诸多错误)1.如下论述中不正确的是(B)。A.在C程序中,是只能用于整数运算的运算符B.在C程序中,无论整数还是实数,都能准确无误地表示C.若a 是实型变量,C程序中a=20是正确的,因此实型变量允许被整型数赋值D.以上表述都是正确的2.若变量x、y、z均为double类型且已正确赋值,不能正确表示x/yz的C语言体现式
4、是(A)。A.x/y*z B.x*(1/(y*z) C.x/y*1/z D.x/y/z3.设a、b、c、d、m、n均为 int型变量,且a=5,b=6,c=7,d=8,m=2,n=2,则逻辑体现式(m=ab)&(n=cd)运算后,n的值为(C)。A.0 B.1 C.2 D.34.设w、x、y、z、m均为int型变量,有如下程序段:w=1; x=2; y=3; z=4;m=(wx)? w:x;m=(my)?m:y;m=(mz)?m:z;则该程序运行后,m的值是(D)。A.4 B.3 C.2 D.15.如下程序的输出成果是(C)。#include main( )int a=5,b=4,c=6,d;
5、 printf(%dn,d=ab?(ac?a:c):(b);A.5 B.4 C.6 D.不确定6.在C语言中,假如下面的变量都是int类型,则输出的成果是(A)。sum=pad=5; pad=sum+ ,pad+ ,+pad;printf(%dn,pad);A.7 B.6 C.5 D.47.如下程序的输出成果是(B)。#include main( )int i=010 , j=10; printf(%d,%dn,+i , j-); A.11,10 B.9,10 C.010,9 D.10,98.已知int i;float f;,由如下选项中正确的语句是(D)。A.(int f)%i; B.int
6、(f)%i; C.int(f%i); D.(int)f%i;9.若有定义:int x=3 ,y=2; float a=2.5 ,b=3.5; 则下面体现式的值为(B)。(x+y)%2+(int)a/(int)bA.1.0 B.1 C.2.0 D.210.假设所有变量均为整型,则体现式 (a=2,b=5,a+,b+,a+b)的值为(C)。A.7 B.8 C.9 D.1011.若有定义int x=1, y=1;, 体现式(!x|y-)的值是(B)。A.0 B.1 C.2 D.-112.有如下程序:main( )unsigned char a,b,c; a=0x3; b=a | 0x8; c=b1;
7、 printf(%d %dn,b,c);程序运行后的输出成果是(D)。A.-1112 B.-6-13 C.1224 D.112213.若已定义x和y为double类型,则体现式x=1,y=x+3/2 的值是(C)。A.1 B.2 C.2.0 D.2.514.执行如下程序段后,c3的值为(A)。int c1=1,c2=2,c3;c3=1.0/c2*c1;A.0 B.0.5 C.1 D.215.如下程序的输出成果是(D)。#include main( )int y=3,x=3,z=1; printf(%d %dn,(+x,y+),z+2);A.34 B.42 C.43 D.33第四章:基本语句1.
8、如下选项中不是C语句的是 C 。A)int i;i+;printf(%dn,i); B);C)a=5,c=10 D) ; 2执行如下程序时输入1234567,程序的运行成果为 B 。#include main() int x,y;scanf(%2d%2ld,&x,&y);printf(%dn,x+y);A)17 B)46 C)15 D)93若有定义char a;int b;float c;double d;,则体现式a*b+c-d成果为型 A 。A)double B)int C)float D)char4若有定义int a,b;,则用语句scanf(%d%d,&a,&b);输入a,b的值时,不
9、能作为输入数据分隔符的是 A 。A), B)空格 C)回车 D)【Tab】键5.运行下面的程序,假如从键盘上输入: abc def则输出成果为 C 。#define N 6#include main() char cN;int i=0;for( ;iN;ci=getchar(),i+);for( i=0;iN;i+) putchar(ci); printf(n);A)abcdefB)abcdC)abcdD)abcdef6如下程序的输出成果是 A 。#include main() printf(%f,2.5+1*7%2/4);A)2.500000 B)2.750000 C)3.375000 D)
10、3.0000007依照定义和数据的输入方式,输入语句的正确形式是 B 。已经有定义:float f1,f2;数据的输入方式:4.523.5A)scanf(%f,%f,&f1,&f2); B)scanf(%f%f,&f1,&f2);C)scanf(%3.2f%2.1f,&f1,&f2); D)scanf(%3.2f,%2.1f,&f1,&f2);8如下程序不用第3个变量,实现将两个数进行对调的操作,请填空。#include main() int a,b;scanf(%d%d,&a,&b);printf(a=%d b=%d,a,b);a=a+b;b=a-b;a= B ;printf(a=%d b=
11、%dn,a,b);A)a+b B)a-b C)b*a D)a/b第五章:选择结构1.如下选项中,能正确表示a10或a0的关系体现式是_D_。A)a=10 or a=10|a=10&a=10 |a=02. 假定所有变量均已正确定义,下列程序段运行后x的值是_B_。a=b=c=0;x=35;if(!a) x-; else if(b);if(c) x=3; else x=4;A)34 B)4 C)35 D)33.如下程序的输出成果_A_。#include main() int a,b,c=246;a=c/100%9;b=(-1)&(-1);printf(%d,%dn,a,b);A)2,1 B)3,2
12、 C)4,3 D)2,-14.已知a=1、b=3、c=5、d=5,下列程序段运行后,x的值是_B_。if(ab)if(cd)x=1;elseif(ac)if(b=0|b=0)&(a0|b=0&b=0)&(a0&b0)&(a+b06. 如下程序的输出成果是_C_。#include main() int a=-1,b=1;if(+a0)& ! (b- =0)printf(%d %dn,a,b);elseprintf(%d %dn,b,a);A)-11 B)01 C)10 D)007.下列有关switch语句和break语句的结论中,正确的是_B_。A)break语句是switch语句中的一部分B)
13、在switch语句中能够依照需要使用或不使用break语句C)在switch语句中必须使用break语句D)break语句只能用于switch语句中8. 若有定义int a=1,b=0;,则执行如下语句后,输出为_B_。switch(a) case 1:switch (b) case 0: printf(*0*); break;case 1: printf(*1*); break;case 2: printf(*2*); break;A)*0* B)*0*2*C)*0*1*2* D)有语法错误9. 如下程序的输出成果是_A_。#include main() int x=1,a=0,b=0;sw
14、itch(x) case 0: b+;case 1: a+;case 2: a+;b+;printf(a=%d,b=%dn,a,b);A)a=2,b=1 B)a=1,b=1 C)a=1,b=0 D)a=2,b=210. 如下程序的输出成果是_C_。#include main() int a=12,b=5,c=-3;if(ab)if(b0) c=0;else c+;printf(%dn,c);A)0 B)1 C)-2 D)-311. 阅读如下程序:#include main() int x;scanf(%d,&x);if(x-5)printf(%d,x);else printf(%d,x+);程
15、序运行后,假如从键盘输入5,则输出成果是_B_。A)3 B)4 C)5 D)612. 两次运行下面的程序,假如从键盘上分别输入6和4,则输出的成果是_A_。#include main( )int x;scanf(%d,&x);if(x+5)printf(%d,x);else printf(%dn,x-);A)7和5 B)6和3 C)7和4 D)6和4第6章循环结构1.在while(x)语句中的x与下面条件体现式等价的是。DA)x=0 B)x=1 C)x!=1 D)x!=02.如下程序的输出成果是。D#include main()int k,j,m;for (k=5;k=1;k-) m=0;fo
16、r (j=k;j=5;j+)m=m+k*j;printf (%dn,m);A)124 B)25 C)36 D)153.如下程序的输出成果是。D#include main() int x=10,y=10,i;for (i=0;x8;y=+i)printf(%d %d,x-,y);A)10 1 9 2 B)9 8 7 6 C)10 9 9 0 D)10 10 9 14.如下程序的输出成果是。Aa=1;b=2;c=2;while(abc) t=a; a=b; b=t; c-;printf (%d,%d,%d,a,b,c);A)1,2,0 B)2,1,0 C)1,2,1 D)2,1,15.如下for循
17、环体的执行次数是。C#include main()int i,j;for(i=0,j=1; i=j+1; i+=2, j-)printf(%dn,i);A)3 B)2 C)1 D)06.有如下程序:#include main() int n=9;while(n6)n-;printf(%d,n);该程序段的输出成果是。BA)987 B)876 C)8765 D)98767.有如下程序段:Aint k=0;while(k=1)k+;while 循环执行的次数是。A)无限次 B)有语法错,不能执行C)一次也不执行 D)执行一次8.如下程序中,while循环的循环次数是。D#include main(
18、) int i=0;while(i10) if(i1) continue;if(i=5) break;i+;A)1 B)10 C)6 D)死循环,不能确定次数9.如下程序的输出成果是。B#includemain() int i=0,a=0;while(i20) for(;) if(i%10)=0)break;elsei-;i+=11;a+=i;printf(%dn,a);A)21 B)32 C)33 D)1110.语句while(!E);中的条件!E等价于。AA)E=0 B)E!=1 C)E!=0 D)E11.如下的for循环。Cfor(x=0,y=0; (y!=123)&(x4); x+ )
19、;A)是无限循环 B)循环次数不定 C)循环执行4次 D)循环执行3次12.执行如下程序段的成果是。Bint x=23;do printf(%d,x-);while(!x);A)打印出321 B)打印出23 C)不打印任何内容 D)陷入死循环第7章:数组1有如下程序:#include #include main() char a =a,b,c,d, e, f, g,h,0; int i,j;i=sizeof(a); j=strlen(a);printf(%d,%dn,i,j);程序运行后的输出成果是。DA)9,9 B)8,9 C)1,8 D)9,82如下程序中函数reverse()的功效是将a
20、所指数组中的内容进行逆置存储。#include void reverse(int a ,int n) int i,t;for(i=0;in/2;i+) t=ai; ai=an-1-i;an-1-i=t;main() int b10=1,2,3,4,5,6,7,8,9,10; int i,s=0;reverse(b,8);for(i=6;i10;i+)s+=bi;printf(%dn,s);则程序运行后的输出成果是。AA)22 B)10 C)34 D)303.有如下程序:main(int argc,char*argv) int n,i=0;while(argv1i!=0) n=fun();i+;
21、printf(%dn,n*argc);int fun() static int s=0;s+=1;return s;假设程序经编译、连接后生成可执行文献exam.exe,若键入如下命令行exam 123则运行成果为。AA)6 B)8 C)3 D)44如下程序的输出成果是。A# include # include main() char str12=s,t,r,i,n,g;printf(%dn,strlen(str); A)6 B)7 C)11 D)125若有阐明:int a34;,则对数组a元素非法引用的是。DA)a02*1 B)a13 C)a4-20 D)a046若有阐明:int a4=0,
22、0;,则如下选项中,不正确的是。DA)数组a的每个元素都可得到初值。B)二维数组a的第一维大小为1C)因为二维数组a中初值的个数不能被第二维大小的值整除,则第一维的大小等于所得商数再加1,故数组a的行数为1D)只有元素a00和a01可得到初值0,其他元素均得不到初值07如下程序中有错误的一行是。D(1)main()(2)(3)int a3=1;(4)int i;(5)scanf(%d,&a);(6)for(i=1;i3;i+) a0=a0+ai;(7)printf(%fn,a0);(8)A)3 B)6 C)7 D)58若有阐明:int a3=1,2,3,4,5,6,7;,则a数组第一维的大小是
23、。BA)2 B)3 C)4 D)无确定值9若有数组定义: char array =China;,则数组 array所占的空间为。CA)4个字节 B)5个字节 C)6个字节 D)7个字节10如下程序的输出成果是。A#include #include string.hmain () char arr24;strcpy(arr,you); strcpy(arr1,me);arr03=&;printf(%sn,arr);A)you&me B)you C)me D)err11有如下程序:#include main() int n5=0,0,0,i,k=2;for(i=0;ik;i+)ni=ni+1;pr
24、intf(%dn,nk);该程序的输出成果是。DA)不定值 B)2 C)1 D)012如下程序的输出成果是。A#include main() int a33=1,2,3,4,5,6,i,j,s=0;for(i=1;i3;i+)for(j=0;ji;j+)s+=aij;printf(%dn,s);A)14 B)19 C)20 D)2113当执行如下程序时,假如输入ABC,则输出成果是。A#include #include main() char ss10=1,2,3,4,5;gets(ss); strcat(ss, 6789); printf(%sn,ss);A)ABC6789 B)ABC67
25、C)12345ABC6 D)ABC45678914如下程序的输出成果是。A#include f(int b,int m,int n) int i,s=0;for(i=m;in;i=i+2)s=s+bi;return s;main() int x,a=1,2,3,4,5,6,7,8,9;x=f(a,3,7);printf(%dn,x);A)10 B)18 C)8 D)1515如下程序中函数sort()的功效是对数组a中的数据进行由大到小的排序。#include void sort(int a,int n) int i,j,t;for(i=0;in-1;i+)for(j=i+1;jn;j+)if(
26、aiaj)t=ai;ai=aj;aj=t;main() int aa10=1,2,3,4,5,6,7,8,9,10,i;sort(&aa3,5);for(i=0;is2) B)if(strcmp(s1,s2) C)if(strcmp(s2,s1)0) D)if(strcmp(s1,s2)0)19如下程序的输出成果是。A#include main() char ch7=12ab56;int i,s=0;for(i=0;chi=0&chi=9;i+=2)s=10*s+chi-0;printf(%dn,s);A)1 B) 1256 C)12ab56 D)120当运行如下程序时,从键盘输入:AhaMA
27、空格 Aha,则程序的输出成果是。A#include main() char s80,c=a;int i=0;scanf(%s,s);while(si!=0) if(si=c) si=si-32;else if(si=c-32) si=si+32;i+;puts(s);A)ahAMa B)AbAMa C)AhAMa空格ahA D)ahAMa空格ahA操作题:1. 下列给定程序中,函数fun( )的功效是:将形参a所指数组中的前半部分元素中的值与后半部分元素中的值对换。形参n中存储数组中数据的个数,若n为奇数,则中间的元素不动。例如:若a所指数组中的数据为:1、2、3、4、5、6、7、8、9,则
28、调换后为:6、7、8、9、5、1、2、3、4。请在空白处填入正确内容,使程序得出正确的成果。(源程序在考生文献夹WEXAM00000000下)不得增行或删行,也不得更改程序的结构!#include #define N 9void fun(int a , int n)int i, t, p;p=(n%2=0)?n/2:n/2+ 1;for(i=0;in/2;i+) t=ai;ai=ap+ i;ap+i=t;main() int bN=1, 2, 3, 4, 5, 6, 7, 8, 9,i;printf(nThe original data:n);for (i=0;iN;i+)printf(%4d
29、,bi);printf(n);fun(b,N);printf(nThe data after moving:n);for (i=0;iN;i+)printf(%4d,bi);printf(n);第八章函数1如下函数值的类型是。Afun ( float x ) float y;y= 3*x-4;return y;A)int B)不确定 C)void D)float2如下程序的输出成果是。B#include int a, b;void fun() a=100; b=200; main() int a=5, b=7;fun();printf(%d%dn, a,b);A)100200 B)57 C)0
30、0 D)753如下程序的输出成果是。C#include int x=3;main() int i; for (i=1;ix;i+)incre();incre() static int x=1;x*=x+1;printf(%d,x);A)33 B)22 C)26 D)254如下程序的输出成果是。B#include int f(int n) if(n=1)return 1;else return f(n-1)+1;main() int i,j=0;for(i=1;i3;i+)j+=f(i);printf(%dn,j);A)4 B)3 C)2 D)15如下程序的输出成果是。A#include int
31、 d=1;fun (int p) int d=5;d+=p+;printf(%d ,d);main( ) int a=3;fun(a);d+=a+;printf(%dn,d); A)84 B)96 C)94 D)856函数调用 strcat(strcpy(str1,str2),str3)的功效是。CA)将字符串str1复制到字符串str2中后再连接到字符串str3之后B)将字符串str1连接到字符串str2之后再复制到字符串str3之后C)将字符串str2复制到字符串str1中后再将字符串str3连接到字符串str1之后D)将字符串str2连接到字符串str1之后再将字符串str1复制到字符串
32、str3中7.有如下程序:int sub(int n) if(n12) return 3;return 1;if(n5) return 2;main() int a=10;printf(%dn,sub(a);该程序的输出成果是。BA)0 B)1 C)2 D)38如下程序的输出成果是。C#include int d=1;fun(int p) static int d=5;d+=p;printf(%d ,d);return(d);main() int a=3;printf(%dn,fun(a+fun(d);A)699 B)669 C)61515 D)66159在一个源文献中定义的外部变量的作用域为
33、。DA)本文献的所有范围 B)本程序的所有范围C)本函数的所有范围 D)从定义该变量的位置开始至本文献结束10.如下论述中正确的是。BA)全局变量的作用域一定比局部变量的作用域范围大B)静态(static)类别变量的生存期贯通于整个程序的运行期间C)函数的形参都属于全局变量D)未在定义语句中赋初值的auto变量和static变量的初值都是随机值11如下对C语言函数的描述中,正确的是。AA)C程序由一个或一个以上的函数组成 B)C函数既能够嵌套定义又能够递归调用C)函数必须有返回值,否则不能使用函数 D)C程序中调用关系的所有函数必须放在同一个程序文献中12.C语言中形参的默认存储类别是。AA)
34、自动(auto) B)静态(static) C)存储器(register) D)外部(extern)13如下论述中不正确的是。BA)在C语言中,调用函数时,只能把实参的值传送给形参,形参的值不能传送给实参B)在C函数中,最佳使用全局变量C)在C语言中,形式参数只是局限于所在函数D)在C语言中,函数名的存储类别为外部14C语言中函数返回值的类型由决定。DA)return语句中的体现式类型 B)调用函数的主调函数类型C)调用函数时的暂时类型 D)定义函数时所指定的函数类型15C语言要求,调用一个函数时,实参变量和形参变量之间的数据传递是。CA)地址传递 B)由实参传给形参,并由形参返回给实参C)值
35、传递 D)由用户指定传递方式16在C语言中。DA)函数的定义能够嵌套,但函数的调用不能够嵌套B)函数的定义和调用均能够嵌套C)函数的定义和调用均不能够嵌套D)函数的定义不能够嵌套,但函数的调用能够嵌套17如下函数调用语句中,含有的实参个数是。Afun(x+y,(e1,e2),fun(xy,d,(a,b);A)3 B)4 C)6 D)818如下程序的输出成果是。C#include fun(int x) static int a=3;a+=x;return(a);main() int k=2,m=1,n;n=fun(k);n=fun(m);printf(%d,n);A)3 B)4 C)6 D)919如下程序的输出成果是。D#include stdio.h