2010年9月全国计算机二级C语言笔试试题:文字版
一、选择题(每小题2分,共70分)
下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。请将正确选项填涂在答题卡相应位置上,答在试卷上不得分。
(1)下列叙述中正确的是
A)线性表的链式存储结构与顺序存储结构所需要的存储空间是相同的 B)线性表的链式存储结构所需要的存储空间一般要多于顺序存储结构 C)线性表的链式存储结构所需要的存储空间一般要少于顺序存储结构 D)上述三种说法都不对
(2)下列叙述中正确的是
A)在栈中,栈中元素随栈底指针与栈顶指针的变化而动态变化 B)在栈中,栈顶指针不变,栈中元素随栈底指针的变化而动态变化 C)在栈中,栈底指针不变,栈中元素随栈顶指针的变化而动态变化 D)上述三种说法都不对
(3)软件测试的目的是 A)评估软件可靠性 B)发现并改正程序中的错误 C)改正程序中的错误 D)发现程序中的错误
(4)下面描述中,不属于软件危机表现的是 A)软件过程不规范 B)软件开发生产率低 C)软件质量难以控制 D)软件成本不断提高
(5)软件生命周期是指
A)软件产品从提出、实现、使用维护到停止使用退役的过程 B)软件从需求分析、设计、实现到测试完成的过程 C)软件的开发过程 D)软件的运行维护过程 (6)面向对象方法中,继承是指 A)一组对象所具有的相似性质 B)一个对象具有另一个对象的性质
1 / 14
文档供参考,可复制、编制,期待您的好评与关注!
C)各对象之间的共同性质 D)类之间共享属性和操作的机制
(7)层次型、网状型和关系型数据库划分原则是 A)记录长度 B)文件的大小 C)了解的复杂程度 D)数据之间的了解方式
(8)一个工作人员可以使用多台计算机,而一台计算机可被多个人使用,则实体工作人员、与实体计算机之间的了解是 A)一对一 B)一对多 C)多对多 D)多对一
(9)数据库设计中反映用户对数据要求的模式是 A)内模式 B)概念模式 C)外模式 D)设计模式
(10)有三个关系R、S和T如下:
则由关系R和S得到关系T的操作是 A)自然连接 B)交 C)投影 D)并
(11)以下关于结构化程序设计的叙述中正确的是
A)一个结构化程序必须同时由顺序、分支、循环三种结构组成 B)结构化程序使用goto语句会很便捷
C)在C语言中,程序的模块化是利用函数实现的 D)由三种基本结构构成的程序只能解决小规模的问题
(12)以下关于简单程序设计的步骤和顺序的说法中正确的是 A)确定算法后,整理并写出文档,最后进行编码和上机调试
2 / 14
文档供参考,可复制、编制,期待您的好评与关注!
B)首先确定数据结构,然后确定算法,再编码,并上机调试,最后整理文档
C)先编码和上机调试,在编码过程中确定算法和数据结构,最后整理文档 D)先写好文档,再根据文档进行编码和上机调试,最后确定算法和数据结构
(13)以下叙述中错误的是
A) C程序在运行过程中所有计算都以二进制方式进行 B)C程序在运行过程中所有计算都以十进制方式进行 C)所有C程序都需要编译链接无误后才能运行
D)C程序中整型变量只能存放整数,实型变量只能存放浮点数
(14)有以下定义:int a; long b; double x,y;则以下选项中正确的表达式是
A)a%(int)(x-y) B)a=x!=y; C)(a*y)%b D)y=x+y=x
(15)以下选项中能表示合法常量的是 A)整数:1,200 B)实数:1.5E2.0 C )字符斜杠:‘\\’ D)字符串:\"\\007\"
(16)表达式a+=a-=a=9的值是 A)9 B)_9 C)18 D)0
(17)若变量已正确定义,在if (W)printf(“%d\\n,k”);中,以下不可替代W的是 A)a<>b+c B)ch=getchar() C)a==b+c D)a++
3 / 14
文档供参考,可复制、编制,期待您的好评与关注!
(18)有以下程序 #include {int a=1,b=0; if(!a) b++; else if(a==0)if(a)b+=2; else b+=3; printf(”%d\n”,b); } 程序运行后的输出结果是 A)0 B)1 C)2 D)3 (19)若有定义语句int a, b;double x;则下列选项中没有错误的是 A)switch(x%2) B)switch((int)x/2.0 {case 0: a++; break; {case 0: a++; break; case 1: b++; break; case 1: b++; break; default : a++; b++; default : a++; b++; } } C)switch((int)x%2) D)switch((int)(x)%2) {case 0: a++; break; {case 0.0: a++; break; case 1: b++; break; case 1.0: b++; break; default : a++; b++; default : a++; b++; } } (20)有以下程序 #include {int a=1,b=2; while(a<6){b+=a;a+=2;b%二10;} printf(”%d,%d\n”,a,b); } 程序运行后的输出结果是 A)5,11 B)7,1 C)7,11 4 / 14 文档供参考,可复制、编制,期待您的好评与关注! D)6,1 (21)有以下程序 #include<stdio.h> main() {int y=10; while(y--); printf(”Y=%d\n”,Y); } 程序执行后的输出结果是 A)y=0 B)y= -1 C)y=1 D)while构成无限循环 (22)有以下程序 #include<stdio .h> main() {char s[」=”rstuv\"; printf(”%c\n”,*s+2); } 程序运行后的输出结果是 A)tuv B)字符t的ASCII码值 C)t D)出错 (23)有以下程序 #include<stdio.h> #include<string.h> main() {char x[]=”STRING”; x[0」=0;x[1]=’\0’;x[2」=’0’; printf(”%d %d\\n”,sizeof(x),strlen(x)); } 程序运行后的输出结果是 A)6 1 B)7 0 C)6 3 5 / 14 文档供参考,可复制、编制,期待您的好评与关注! D)7 1 (24)有以下程序 #include<stdio.h> Int f(int x); main() {int n=1,m; m=f(f(f(n)));printf(”%d\n”,m); } int f(int x) {return x*2;} 程序运行后的输出结果是 A)1 B)2 C)4 D)8 (25)以下程序段完全正确的是 A)int *p; scanf(\"%d\&p); B)int *p; scanf(“%d”,p); C)int k, *p=&k; scanf(\"%d\); D)int k, *p:; *p= &k; scanf(“%d”,p); (26)有定义语句:int *p[4];以下选项中与此语句等价的是 A)int p[4]; B)int **p; C)int *(p「4」); D)int (*p)「4」; (27)下列定义数组的语句中,正确的是 A)int N=10; B)#define N 10 int x[N]; int x[N]; C)int x[0..10]; D)int x[]; (28)若要定义一个具有5个元素的整型数组,以下错误的定义语句是 A)int a[5]=﹛0﹜; B)int b[]={0,0,0,0,0}; C)int c[2+3]; 6 / 14 文档供参考,可复制、编制,期待您的好评与关注! D)int i=5,d[i]; (29)有以下程序 #include<stdio.h> void f(int *p); main() {int a[5]={1,2,3,4,5},*r=a; f(r);printf(”%d\\n”;*r); } void f(int *p) {p=p+3;printf(”%d,”,*p);} 程序运行后的输出结果是 A)1,4 B)4,4 C)3,1 D)4,1 (30)有以下程序(函数fun只对下标为偶数的元素进行操作) # include<stdio.h> void fun(int*a;int n) {int i、j、k、t; for (i=0;i<n一1;1+=2) {k=i;‘ for(j=i;j {int aa「10」={1、2、3、4、5、6、7},i; fun(aa、7); for(i=0,i<7; i++)printf(”%d,”,aa[i])); printf(”\n”); } 程序运行后的输出结果是 A)7,2,5,4,3,6,1 B)1,6,3,4,5,2,7 C)7,6,5,4,3,2,1 D)1,7,3,5,6;2,1 7 / 14 文档供参考,可复制、编制,期待您的好评与关注! (31)下列选项中,能够满足“若字符串s1等于字符串s2,则执行ST\"要求的是 A)if(strcmp(s2,s1)==0)ST; B)if(sl==s2)ST; C)if(strcpy(s l ,s2)==1)ST; D)if(sl-s2==0)ST; (32)以下不能将s所指字符串正确复制到t所指存储空间的是 A)while(*t=*s){t++;s++;} B)for(i=0;t[i]=s[i];i++); C)do{*t++=*s++;}while(*s); D)for(i=0,j=0;t[i++]=s[j++];); (33)有以下程序( strcat函数用以连接两个字符串) #include<stdio.h> #include<string .h> main() {char a[20]=”ABCD\OEFG\0”,b[]=”IJK”; strcat(a,b);printf(”%s\\n”,a); } 程序运行后的输出结果是 A)ABCDE\\OFG\\OIJK B)ABCDIJK C)IJK D)EFGIJK (34)有以下程序,程序中库函数islower (ch)用以判断ch中的字母是否为小写字母 #include<stdio.h> #include<ctype.h> void fun(char*p) {int i=0; while (p[i]) {if(p[i]==’ ’&& islower(p「i-1」))p[i-1]=p[i-1]-‘a’+‘A’; i++; } } 8 / 14 文档供参考,可复制、编制,期待您的好评与关注! main() {char s1[100]=”ab cd EFG!”; fun(s1); printf(”%s\\n”,s1); } 程序运行后的输出结果是 A)ab cd EFG! B)Ab Cd EFg! C)aB cD EFG! D)ab cd EFg! (35)有以下程序 #include<stdio.h> void fun(int x) {if(x/2>1)fun(x/2); printf(”%d”,x); } main() {fun(7);printf(”\\n”);} 程序运行后的输出结果是 A)1 3 7 B)7 3 1 C)7 3 D)3 7 (36)有以下程序 #include<stdio.h> int fun() {static int x=1; x+=1;return x; } main() {int i;s=1; for(i=1;i<=5;i++)s+=fun(); printf(”%d\n”,s); } 程序运行后的输出结果是 A)11 B)21 9 / 14 文档供参考,可复制、编制,期待您的好评与关注! C)6 D)120 (37)有以下程序 #inctude<stdio.h> #include<stdlib.h> Main() {int *a,*b,*c; a=b=c=(int*)malloc(sizeof(int)); *a=1;*b=2,*c=3; a=b; printf(“%d,%d,%d\n”,*a,*b,*c); } 程序运行后的输出结果是 A)3,3,3 B)2,2,3 C)1,2,3 D)1,1,3 (38)有以下程序 #include<stdio.h> main() {int s,t,A=10;double B=6; s=sizeof(A);t=sizeof(B); printf(“%d,%d\n”,s,t); } 在VC6平台上编译运行,程序运行后的输出结果是 A)2,4 B)4,4 C)4,8 D)10,6 (39)若有以下语句 Typedef struct S {int g; char h;}T; 以下叙述中正确的是 A)可用S定义结构体变量 B)可用T定义结构体变量 C)S是struct类型的变量 D)T是struct S类型的变量 (40)有以下程序 #include<stdio.h> main() 10 / 14 文档供参考,可复制、编制,期待您的好评与关注! {short c=124; c=c_______; printf(“%d\n”、C); } 若要使程序的运行结果为248,应在下划线处填入的是 A)>>2 B)|248 C)&0248 D)<请将每空的正确答案写在答题卡【1】至【15】序号的横线上,答在试卷上不得分。 (1)一个栈的初始状态为空。首先将元素5,4,3,2,1依次入栈,然后退栈一次,再将元素 A,B,C,D依次入栈,之后将所有元素全部退栈,则所有元素退栈(包括中间退栈的元素)的顺序为【1】 (2)在长度为n的线性表中,寻找最大项至少需要比较【2】次。 (3)一棵二叉树有10个度为1的结点,7个度为2的结点,则该二叉树共有【3】个结点。 (4)仅由顺序、选择(分支)和重复(循环)结构构成的程序是【4】程序。 (5)数据库设计的四个阶段是:需求分析,概念设计,逻辑设计【5】。 (6)以下程序运行后的输出结果是【6】。 #include<stdio.h> main() {int a=200,b=010; printf(”%d%d\\n”,a,b); } (7)有以下程序 #include<stdio.h> main() {int x,Y; scanf(”%2d%ld”,&x,&y);printf(”%d\n”,x+y); } 程序运行时输入:1234567程序的运行结果是【7】。 11 / 14 文档供参考,可复制、编制,期待您的好评与关注! (8)在C语言中,当表达式值为0时表示逻辑值“假”,当表达式值为【8】时表示逻辑值“真”。 (9)有以下程序 #include<stdio.h> main() {int i,n[]={0,0,0,0,0}; for (i=1;i<=4;i++) {n[i]=n[i-1]*3+1; printf(”%d \);} } 程序运行后的输出结果是【9】。 (10)以下fun函数的功能是:找出具有N个元素的一维数组中的最小值,并作为函数值返回。请填空。(设N已定义) int fun(int x[N]) {int i,k=0; for(i=0;i {int m=1,n=2,*r=&m; r=f(r,&n);printf(”%d\n”,*r); } int*f(int *p,int*q) {return(*p>*q)?p:q;} 程序运行后的输出结果是【11】 (12)以下fun函数的功能是在N行M列的整形二维数组中,选出一个最大值作为函数值返回,请填空。(设M,. N已定义) int fun(int a[N][M)) {int i,j,row=0,col=0; for(i=0;i 文档供参考,可复制、编制,期待您的好评与关注! for(j=0;j if(a[i][j]>a[row][col]){row=i;col=j;} return(【12】): } (13)有以下程序 #include<stdio.h> main() {int n[2],i,j; for(i=0;i<2;i++)n[i]=0; for(i=0;i<2;i++) for(j=0;j<2;j++)n[j]=n「i」+1; printf(”%d\\n”,n[1]); } 程序运行后的输出结果是【13】 (14)以下程序的功能是:借助指针变量找出数组元素中最大值所在的位置并输出该最大值。请在输出语句中填写代表最大值的输出项。 #include<stdio.h> main() {int a〔10],*p,*s; for(p=a;p-a<10;p++)scanf(”%d”,p); for(p=a,s=a;p-a<10;p++)if(*p>*s)S=P; printf(\"max=%d\\n”,【14】); } (15)以下程序打开新文件f.txt,并调用字符输出函数将a数组中的字符写入其中,请填空。 #include<stdio.h> main() {【15】*fp; char a[5]={’1’,’2’,’3’,’4’,’5’},i; fp=fopen(”f .txt”,”w”); for(i=0;i<5;i++)fputc(a[i],fp); fclose(fp); } 13 / 14 文档供参考,可复制、编制,期待您的好评与关注! 温馨提示-专业文档供参考,请仔细阅读后下载,最好找专业人士审核后使用! 14 / 14 因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- shangjiatang.cn 版权所有 湘ICP备2022005869号-4
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务