![]() ![]() |
|
1996年4月全国计算机等级考试二级C语言笔试试题及答案 | |
作者:佚名 文章来源:不详 点击数 更新时间:2008/4/18 14:06:32 文章录入:杜斌 责任编辑:杜斌 | |
|
|
一、选择题((1)-(40)每小题1分,(41)-(50)每小题2分,共60分) (11) 为了要将A盘当前目录(不是根目录)中所有扩展名为.C的文件同名复制到A痰哪柯糪USER中,正确的命令是 A.COPY A:*.C USER\*.C B.COPY A:*.C A:\USER C.COPY A:*.C A:USER\ D.COPY A:*.C A:USER\*.C (12) 为了在屏幕上一次显示当前盘当前目录下的所有扩展名为.TXT的文件内容,下列命令中正确的是 A.TYPE *.TXT B.TYPE *.TXT CON C.COPY *.TXT>CON D.COPY *.TXT CON (13) 设当前盘为A盘,为了将当前盘当前目录下的文件AB1.TXT连接在C盘根目录下的文件XYZ.TXT的后面,正确的命令是 A.COPY C:\XYZ.TXT+AB1.TXT B.COPY AB1.TXT>>C:\XYZ.TXT C.TYPE AB1.TXT>C:\XYZ.TXT D.COPY AB1.TXT+C:\XYZ.TXT>C:\XYZ.TXT (14) 设A盘为启动盘,其目录结构为(画方框的为目录) 其中文件AUTOEXEC.BAT的内容为 MD \XYZ CD \DOS\USER 则由A盘启动成功后,A盘的当前目录是 A.\DOS\USER B.\XYZ C.\ D.\DOS (15) 下列DOS命令中为内部命令的是 A.COMP B.PATH C.PRINT D.FORMAT (16) 设当前盘为C盘,所用的所有软盘已格式化且容量相同,则下列DOS命令中错误的是 (21) 设a、b和c都是int型变量,且a=3,b=4,c=5,则下面的表达式中,值为0的表达式是 A.’a’&&’b’ B.a<=b C.a||b+c&&b-c D.!((a(22) 请读程序片段: int i=65536; printf("%d\n",i); 上面程序片段的输出结果是 A.65536 B.0 C.有语法错误,无输出结果 D.-1 (23) 设ch是char型变量,其值为A,且有下面的表达式: ch=(ch>=’A’&&ch<=’Z’)?(ch+32):ch 上面表达式的值是 A.A B.a C.Z D.z (24) 若x和y都是int型变量,x=100,y=200,且有下面的程序片段: printf("%d",(x,y)); 上面程序片段的输出结果是 A.200 B.100 C.100 200 D.输出格式符不够,输出不确定的值 (25) 下面各语句行中,能正确进行赋字符串操作的语句行是 A.char st[4][5]={"ABCDE"}; B.char s[5]={’A’,’B’,’C’,’D’,’E’}; C.char *s; s="ABCDE"; D.char *s; scanf("%s",s); (26) 若k是int型变量,且有下面的程序片段: k=-3 if(k<=0) printf("####") else printf("&&&&"); 上面程序片段的输出结果是 A.#### B.&&&& C.####&&&& D.有语法错误,无输出结果 (27) 若x是int型变量,且有下面的程序片段: for(x=3; x<6; x++) printf((x%2)?("**%d"):("##%d\n"),x); 上面程序片段的输出结果是 A.**3 B.##3 C.##3 D.**3##4 ##4 **4 **4##5 **5 **5 ##5 (28) 请读程序: #include f(char *s) { char *p=s; while( *p!=’\0’) p++; return(p-s); } main() { printf("%d\n",f("ABCDEF"));} 上面程序的输出结果是 A.3 B.6 C.8 D.0 (29) 请读程序: #include main() { int a; float b, c; scanf("-?O",&a,&b,& C.; printf("\na=%d, b=%f, c=%f\n", a, b, C.; } 若运行时从键盘上输入9876543210(表示回车),则上面程序的输出结果是 A.a=98, b=765, c=4321 B.a=10, b=432, c=8765 C.a=98, b=765.000000, c=4321.000000 D.a=98, b=765.0, c=4321.0 (30) 请读程序: #include main() { int n[2], i, j, k; for(i=0;i<2;i++) n[i]=0; k=2 for(i=0;ifor(j=0;jprintf("%d\n",n[k]); } 上面程序的输出结果是 A.不确定的值 B.3 C.2 D.1
(31) 请读程序片段: (41) 请读程序: #include main() { int mun=0; while(num<=2) { num++; printf("%d\n",num);} } 上面程序的输出结果是 A.1 B.1 C.1 D.1 2 2 2 3 3 4 (42) 请读程序: #include main() { float x,y; scan("%f",&x); if(x<0.0) y=0.0 else if((x<5.0)&&(x!=2.0)) y=1.0/(x+2.0); else if (x<10.0) y=1.0/x; else y=10.0; printf("%f\n",y); } 若运行时从键盘上输入2.0(表示回车),则上面程序的输出结果是 A.0.000000 B.0.250000 C.0.500000 D.1.000000 (43) 请读程序: #include main() { int x=1, y=0, a=0, b=0; switch(x) { case 1: switch(y) { case 0: a++;break; case 1: b++;break; } case 2: a++; b++; break; } printf("a=%d, b=%d\n",a, B.; } 上面程序的输出结果是 A.a=2, b=1 B.a=1, b=1 C.a=1, b=0 D.a=2, b=2 (44) 若有下面的程序片段: int a[12]={0}, *p[3], **pp, i; for(i=0; i<3; i++) p[i]=&a[i*4]; pp=p; 则对数组元素的错误引用是 A.pp[0][1] B.a[10] C.p[3][1] D.*(*(p+2)+2) (45) 请读程序: #include #include main() { float x,y,z; scan("%f%f",&x,&y); z=x/y; while(1) { if(fabs(z)>1.0) { x=y; y=z; z=x/y; } else break } printf("%f\n",y); } 若运行时从键盘上输入3.6 2.4(表示回车),则输出的结果是 A.1.500000 B.1.600000 C.2.000000 D.2.400000 (46) 请读程序: #include f(in b[], int n) { int i, r; r=1; for(i=0; i<=n; i++) r=r*b[i]; return r; } main() { int x, a[]={ 2,3,4,5,6,7,8,9}; x=f(a, 3); printf("%d\n",x); } 上面程序的输出结果是 A.720 B.120 C.24 D.6 (47) 请读程序: #include #include void fun( char *s) { char a[10]; strcpy( a, "STRING"); s=a; } main() { char *p; fun(p); x=f(a, 3); printf("%s\n",p); } 上面程序的输出结果是(└┘表示空格) A.STRING└┘└┘└┘└┘ B.STRING C.STRING└┘└┘└┘ D.不确定的值 (48) 若已建立下面的链表结构,指针p、s分别指向图中所示的结点,则不能将s所指的结点插入到链表末尾的语句组是 A.s->next=NULL; p=p->next; p->next=s; B.p=p->next; s->next=p->next; p->next=s; C.p=p->next; s->next=p; p->next=s; D.p=(*p).next; (*s).next=(*p).next; (*p).next=s; (49) 请读程序: #include void fun(float *pl, float *p2, float *s) { s=( float * )calloc( 1, sizeof(float)); *s=*p1+ *(p2++); } main() { float a[2]={1.1, 2.2}, b[2]={10.0, 20.0}, *s=a; fun(a, b, s) printf("%f\n",*s); } 上面程序的输出结果是 A.11.100000 B.12.100000 C.21.100000 D.1.100000 (50) 请读程序: #include #include void fun( char *w, int m) { char s, *p1, *p2; p1=w; p2=w+m-1; while (p1{ s=*p1++; *p1=*p2--; *p2=s;} } main() { char a[]="ABCDEFG"; fun( a, strlen(a)); puts(a); } 上面程序的输出结果是 A.GFEDCBA B.AGADAGA C.AGAAGAG D.GAGGAGA 二、填空题(每空2分,共40分) 请将每空的正确答案写在答题卡上【1】-【20】序号后的横线上,答在试卷上不得分。 (1) DOS命令分为内部命令与外部命令,XCOPY命令是 【1】 命令 (2) 为了列出当前盘当前目录中所有第三个字符为C的文件名的有关信息,应该用命令 【2】 。 (3) 设当前盘为A盘,当前目录为\X\Y,A盘上的一个文件QR.C在当前目录下的子目录W中。现已将A盘的当前目录改为\D\XY,当前盘改为C盘,如需指定A盘上该文件应写成 【3】 。 (4) 用十六进制给存储器中的字节地址进行编号,其地址编号是从0000到FFFF,则该存储器的容量是【4】KB。 (5) 设有两个八位二进制数00010101与01000111相加,其结果的十进制表示为 【5】 。 (6) 数学式子 写成C语言表达式是 【6】 。 (7) 下面程序的输出结果是 【7】 。 #include main() { static char b[]="Goodbye"; char *chp=&b[7]; while( --chp >=&b[0]) putchar( *chp); putchar(’\n’); } (8) 下面程序的输出结果是 【8】 。 #include void as( int x, int y, int *cp, int *dp) { *cp=x+y; *dp=x-y; } main() { int a=4, b=3, c, d; as( a, b, &c, &d); printf( ’%d %d\n", c, d); } (9) 请读程序: #include main( int argc, char *argv[]) { int i; printf( ’%d\n", argc); for( i=0; i<=argc+1; i++) printf( "%s ", argv[i]); printf("\n"); } 若上面的程序编译、连接后生成可执行文件ABC.EXE,则输入以下命令行 abc file1 file2(表示回车) 程序执行后的输出结果是 【9】 。 (10) 条件“20(11) 设二进制数a是00101101,若想通过异或运算a^b使a的高4位取反,低4位不变,则二进制数b应是 【11】 。 (12) 若有以下说明和定义语句,则变量w在内存中所占的字节数是 【12】 。 union aa { float x, y; char c[6]; }; struct st { union aa v; float w[5]; double ave; } w; (13) 下面程序的输出结果是 【13】 。 #include #define N 5 fun( char *s, char a, int n) { int j; *s=a; j=n; while( ereturn j; } main() { char s[N+1]; int k, p; for( k=1; k<=N; k++) s[k]=’A’+k+1; printf( "%d\n", fun(s, ’E’, N)); } (14) 下面程序的输出结果是 【14】 。 #include void fun( char *a1, char *a2, int n) { int k; for( k=0; ka2[k]=( a1[k]-’A’-3+26)&+’A’; a2[n]=’\0’; } main() { char s1[5]="ABCD", s2[5]; fun( s1, s2, 4); puts( s2); } (15) 下面的findmax函数返回数组s中最大元素的下标,数组中元素的个数由t传入,请填空。 findmax( int s[], int t) { int k, p; for( p=0, k=p; pif( s[p]>s[k]) 【15】 。 return k; } (16) 下面程序的输出结果是 【16】 。 #include fun( int x) { int p; if( x==0||x==1) return(3); p=x-fun( x-2); return p; } main() { printf( "%d\n", fun(9));} (17) 下面程序的输出结果是 【17】 。 #include funa( int a, int b) { return a+b;} funb( int a, int b) { return a-b;} sub( int (*t)(), int x, int y) { return((*t)( x,y));} main() { int x, (*p)(); p=funa; x=sub(p,9,3); x+=sub(funb, 8, 3); printf("%d\n", x); } (18) 下面程序的输出结果是 【18】 。 #include main() { char *p[]={ "BOOL", "OPK", "H", "SP"}; int i; for(i=3; i>=0; i--,i--) printf( "%c", *p[i]); printf("\n"); } (19) 为了建立如图所示的存储结构(即每个结点含两个域,data是数据域,next是向结点的指针域),请填空。 data next struct link { char data; 【19】 } node; (20) 下面的程序用来统计文件中字符的个数,请填空。 #include main() { FILE *fp; long num=0; if(( fp=fopen("fname.dat","r"))==NULL) { printf( "Can’t open file! \n"); exit(0);} while 【20】 { fgetc(fp); num++;} printf("num=%d\n", num); fclose(fp); }
1996年4月二级C语言笔试试卷参考答案 一`选择题((1)~(40)题每题1分,(41)~(50)题每题2分,共60分) |
|
![]() ![]() |