2008 年 9 月全国计算机二级 C++考试真题及答案
一、选择题(每小题 2 分,共 70 分)
(1)一个栈的初始状态为空。现将元素 1、2、3、4、5、A、B、C、D、E 依次入栈,
然后再依次出栈,则元素出栈的顺序是(B)。
A)123456ABCDE
C)ABCDE12345
B)EDCBA54321
D)54321EDCBA
(2)下列叙述中正确的是(D)。
A)循环队列有队头和队尾两个指针,因此,循环队列是非线性结构
B)在循环队列中,只需要队头指针就能反映队列中元素的动态变化情况
C)在循环队列中,只需要队尾指针就能反映队列中元素的动态变化情况
D)循环队列中元素的个数是由队头指针和队尾指针共同决定
(3)在长度为 n 的有序线性表中进行二分查找,最坏情况下需要比较的次数是(C)。
A)O(n)
C)O(log2n)
B)O(n2)
D)O(nlog2n)
(4)下列叙述中正确的是(A)。
A)顺序存储结构的存储一定是连续的,链式存储结构的存储空间不一定是连续的
B)顺序存储结构只针对线性结构,链式存储结构只针对非线性结构
C)顺序存储结构能存储有序表,链式存储结构不能存储有序表
D)链式存储结构比顺序存储结构节省存储空间
(5)数据流图中带有箭头的线段表示的是(D)。
A)控制流
C)模块调用
B)事件驱动
D)数据流
(6)在软件开发中,需求分析阶段可以使用的工具是(B)。
A)N-S 图
B)DFD 图(数据流图)
C)PAD 图
D)程序流程图
(7)在面向对象方法中,不属于“对象”基本特点的是(A)。
A)一致性
B)分类性
C)多态性
D)标识唯一性
(8)一间宿舍可住多个学生,则实体宿舍和学生之间的联系是(B)。
1
A)一对一
B)一对多
C)多对一
D)多对多
(9)在数据管理技术发展的三个阶段中,数据共享最好的是(C)。
A)人工管理阶段
B) 文件系统阶段
C)数据库系统阶段
D) 二个阶段相同
(10)有三个关系 R、S 和 T 如下:
R
S
T
A
m
B
1
B
1
C
3
n
2
3
5
A
m
B
1
C
3
由关系 R 和 S 通过运算得到关系 T,则所使用的运算为(D)。
A)笛卡尔积
B)交
C)并
D)自然连接
(11)在下列原型所示的 C++函数中,按“传值”方式传递参数的是(A)。
A)void f1(int x);
B)void f2(int*x);
C)void f3(const int*x); D)void f4(int&x);
(12)在 C++中,编译系统自动为一个类生成缺省构造函数的条件是(C)。
A)该类没有定义任何有参构造函数
B)该类没有定义任何无参构造函数
C)该类没有定义任何构造函数
D)该类没有定义任何成员函数
(13)在一个派生类的成员函数中,试图调用其基类的成员函数“void f();”,但无法通过
编译。这说明(A)。
A)f()是基类的私有成员
C)派生类的继承方式为私有
B)f()是基类的保护成员
D)派生类的继承方式为保护
(14)下列关于运算符重载的叙述中,错误的是(B)。
A)有的运算符可以作为非成员函数重载
B)所有的运算符都可以通过重载而被赋予新的含义
2
C)不得为重载的运算符函数的参数设置默认值
D)有的运算符只能作为成员函数重载
(15)下列关于模板的叙述中,错误的是(C)。
A)调用模版函数时,在一定条件下可以省略模板实参
B)可以用 int、double 这样的类型修饰符来声明模版参数
C)模板声明中的关键字 class 都可以用关键字 typename 替代
D)模板的形参表中可以有多个参数
(16)要利用 C++流进行文件操作,必须在程序中包含的头文件是(B)。
A)iostream
B)fstream
C)strstream
D)iomanip
(17)下列字符串中不能作为 C++标识符使用的是(D)。
A)WHILE B)user C)_lvar D)9stars
(18)下列语句中错误的是(A)。
A)const int a;
B)const int a=10;
C)const int*point=0;
D)const int*point=new int(10);
(19)有如下程序:
#include
using namespace std;
int main(){
int sum;
for(int i=0; i<6; i+=3){
sum=i;
for(int j = i; j<6; j++)sum+=j;
}
cout<
using namespace std;
class Sample{
public:
Sample(){}
~Sample(){cout<<'*';}
};
int main(){
Sample temp[2], *pTemp[2];
return 0;
}
执行这个程序输出星号(*)的个数为(B)。
A)1
B)2
C)3
D)4
(23)下列选项中,与实现运行时多态性无关的是(A)。
A)重载函数
B)虚函数
C)指针
D)引用
(24)下列运算符函数中,肯定不属于类 Value 的成员函数的是(B)。
A)Value operator+(Value);
B)Value operator-(Value, Value);
4
C)Value operator*(int);
D)Value operator/(Value);
(25)下列模板声明中,有语法错误的是(D)。
A)templateT fun(T x){return x;}
B)templateT fun(T x, int n){return x*n;}
C)templateT fun(T *p){return *p;}
D)templateT classA{T n;};
(26)在语句“cout<<'A';”中,cout 是(B)。
A)类名
B)对象名
C)函数名
D)C++的关键字
(27)有如下程序:
#include
using namespace std;
class MyClass{
public:
MyClass(int i=0){cout<<1;}
MyClass(const MyClass&x){cout<<2;}
MyClass& operator=(const MyClass&x)
{cout<<3; return*this;}
~MyClass(){cout<<4;}
};
int main(){
MyClass obj1(1),obj2(2),obj3(obj1);
return 0:
}
运行时的输出结果是(A)。
A)112444
B)11114444
C)121444
D)11314444
(28)有如下程序:
#include
using namespace std;
5
温馨提示:当前文档最多只能预览 6 页,此文档共13 页,请下载原文档以浏览全部内容。如果当前文档预览出现乱码或未能正常浏览,请先下载原文档进行浏览。
1 / 6 13