logo资料库

2005年4月全国计算机二级C++考试真题及答案.doc

第1页 / 共15页
第2页 / 共15页
第3页 / 共15页
第4页 / 共15页
第5页 / 共15页
第6页 / 共15页
第7页 / 共15页
第8页 / 共15页
资料共15页,剩余部分请下载后查看
2005 年 4 月全国计算机二级 C++考试真题及答案 (考试时间 90 分钟,满分 100 分) 一、选择题((1)-(10)每小题 2 分,(11)-(50)每小题 1 分,共 60 分) 下列各题 A)、B)、C)、D)四个选项中,只有一个选项是正确的。请将正确选项真涂在答题卡相应位置上,答在 试卷上不得分。 (1)数据的存储结构是指 A)存储在外存中的数据 B)数据所占的存储空间量 C)数据在计算机中的顺序存储方式 D)数据的逻辑结构中计算机中的表示 (2)下列关于栈的描述中错误的是 A)栈是先进后出的线性表 B)栈只能顺序存储 C)栈具有记忆作用 D)对栈的插入与删除操作中,不需要改变栈底指针 (3)对于长度为 n 的线性表,在最坏情况下,下列各排序法所对应的比较次数中正确的是 A)冒泡排序为 n/2 B)冒泡排序为 n C)快速排序为 n D)快速排序为 n(n-1)/2 (4)对长度为 n 的线性表进行顺序查找,在最坏情况下所需要的比较次数为 A)log2n B) n/2 C) n D) n+1 (5)下列对于线性链表的描述中正确的是 A)存储空间不一定是连续,且各元素的存储顺序是任意的 B)存储空间不一定是连续,且前件元素一定存储在后件元素的前面 C)存储空间必须连续,且前件元素一定存储在后件元素的前面 D)存储空间必须连续,且各元素的存储顺序是任意的 (6)下列对于软件的描述中正确的是 A)软件测试的目的是证明程序是否正确 B)软件测试的目的是使程序运行结果正确 C)软件测试的目的是尽可能多地发现程序中的错误 D)软件测试的目的是使程序符合结构化原则 (7)为了使模块尽可能独立,要求 A)模块的内聚程序要尽量高,且各模块间的耦合程序要尽量强 B)模块的内聚程序要尽量高,且各模块间的耦合程序要尽量弱 C)模块的内聚程序要尽量低,且各模块间的耦合程序要尽量弱 D)模块的内聚程序要尽量低,且各模块间的耦合程序要尽量强 (8)下列描述中正确的是 A)程序就是软件 B)软件开发不受计算机系统的限制 C)软件既是逻辑实体,又是物理实体
D)软件是程序、数据与相关文档的集合 (9)数据独立性是数据库技术的重要特点之一。所谓数据独立性是指 A)数据与程序独立存放 B)不同的数据被存放在不同的文件中 C)不同的数据只能被对应的应用程序所使用 D)以上三种说法都不对 (10)用树形结构表示实体之间联系的模型是 A)关系模型 B)网状模型 C)层次模型 D)以上三个都是 (11)算法具有五个特性,以下选项中不属于算法特性的是 A)有穷性 B)简洁性 C)可行性 D)确定性 (12)以下选项中可作为 C 语言合法常量的是 A)-80. B)-080 C)-8e1.0 D)-80.0e (13)以下叙述中正确的是 A)用 C 程序实现的算法必须要有输入和输出操作 B)用 C 程序实现的算法可以没有输出但必须要有输入 C)用 C 程序实现的算法可以没有输入但必须要有输出 D)用 C 程序实现的算法可以既没有输入也没有输出 14.以下不能定义为用户标识符的是 A)Main B)_0 C)_int D)sizeof (15)以下选项中,不能作为合法常量的是 A)1.234e04 B)1.234e0.4 C)1.234e+4 D)1.234e0 (16)数字字符 0 的 ASCII 值为 48,若有以下程序 main() { a='1',b='2'; char printf("%c,",b++); printf("%d\n",b-a); } 程序运行后的输出结果是 A)3,2 B)50,2 C)2,2
D)2,50 (17)有以下程序 main() { int m=12,n=34; printf("%d%d",m++,++n); printf("%d%d\n",n++,++m); } 程序运行后的输出结果是 A)12353514 B)12353513 C)12343514 D)12343513 (18)有定义语句:int A)scanf("%d%s",&b,&c); B)scanf("%d%s",&b,c); C)scanf("%d%s",b,c); D)scanf("%d%s",b,&c); (19)有以下程序 main() { m,n,p; b;char c[10]; ,则正确的输入语句是 int scanf("m=%dn=%dp=%d",&m,&n,&p); printf("%d%d%d\n",m,n,p); n=456 } 若想从键盘上输入数据,使变量 m 中的值为 123,n 中的值为 456,p 中的值为 789,则正确的输入是 A)m=123n=456p=789 B)m=123 C)m=123,n=456,p=789 D)123 789 (20)有以下程序 main() { p=789 456 a,b,d=25; int a=d/10%9; b=a&&(-1); printf("%d,%d\n",a,b); } 程序运行后的输出结果是 A)6,1 B)2,1 C)6,0 D)2,0 (21)有以下程序 main() { if(i++==1&&(++j==3||k++==3)) i=1,j=2,k=3; int printf("%d %d %d\n",i,j,k);
3 4 3 3 2 3 2 3 } 程序运行后的输出结果是 A)1 B)2 C)2 D)2 (22)若整型变量 a、b、c、d 中的值依次为:1、4、3、2。则条件表达式 ay?x:y;} x>y?y:x;}
程序运行后的输出结果是 A)4,3,7 B)3,4,7 C)5,2,7 D)2,5,7 (27)已有定义:char a[]="xyz",b[]={'x','y','z'};,以下叙述中正确的是 A)数组 a 和 b 的长度相同 B)a 数组长度小于 b 数组长度 C)a 数组长度大于 b 数组长度 D)上述说法都不对 (28)有以下程序 void {int f(int t; *x,int *y) t=*x;*x=*y;*y=t; a[8]={1,2,3,4,5,6,7,8},i,*p,*q; } main() { int p=a;q=&a[7]; while(p
D)3 4 5 (30)以下叙述中错误的是 A)对于 double 类型数组,不可以直接用数组名对数组进行整体输入或输出 B)数组名代表的是数组所占存储区的首地址,其值不可改变 C)当程序执行中,数组元素的下标超出所定义的下标范围时,系统将给出“下标越界”的出错信息 D)可以通过赋初值的方式确定数组元素的个数 (31)有以下程序 #define 20 fun(int { N a[],int n,int m) int i,j; for(i=m;i>=n;i--) a[i+1]=a[i]; } main() { int i,a[N]={1,2,3,4,5,6,7,8,9,10}; fun(a,2,9); for(i=0;i<5;i++) printf("%d",a[i]); } 程序运行后的输出结果是 A)10234 B)12344 C)12334 D)12234 (32)有以下程序 main() { int for(i=0;i<2;i++) { ptr=a+i; a[3][2]={0},(*ptr)[2],i,j; scanf("%d",ptr); ptr++; } for(i=0;i<3;i++) { for(j=0;j<2;j++) printf("%2d",a[i][j]); 2 3<回车>,则输出结果为 printf("\n"); } } 若运行时输入:1 A)产生错误信息 B)1 0 2 0 0 0 C)1 2
3 0 0 0 D)1 0 2 0 3 0 (33)有以下程序 prt(int { *m,int n) int i; for(i=0;i
D)编译出错 (36)有以下程序 main() { int c=35; printf("%d\n",c&c); } 程序运行后的输出结果是 A) 0 B) 70 C) 35 D) 1 (37)以下叙述中正确的是 A)预处理命令行必须位于源文件的开头 B)在源文件的一行上可以有多条预处理命令 C)宏名必须用大写字母表示 D)宏替换不占用程序的运行时间 (38)若有以下说明和定义 union { dt int a; char b; double c; }data; 以下叙述中错误的是 A)data 的每个成员起始地址都相同 B)变量 data 所占内存字节数与成员 c 所占字节数相等 C)程序段:data.a=5;printf("%f\n",data.c);输出结果为 5.000000 D)data 可以作为函数的实参 (39)以下语句或语句组中,能正确进行字符串赋值的是 A)char *sp; B)char s[10]; C)char D)char (40)设有如下说明 typedef struct { *sp="right!"; s="right!"; s[10]; *sp="right!"; *s="right!"; ST long a; int char b; c[2]; } NEW; 则下面叙述中正确的是 A)以上的说明形式非法 B)ST 是一个结构体类型 C)NEW 是一个结构体类型 D)NEW 是一个结构体变量 (41)有以下程序 main() {
分享到:
收藏