第一题  下面的程序的输出结果是:

A. 134122

B. 123412

C. 14302012

D. 143212

#include <iostream>
using namespace std; class Base
{
public:
Base(int i){cout << i;}
~Base(){}
};
class Base1:virtual public Base
{
public:
Base1(int i, int j=0):Base(j){cout <<i;}
~Base1(){}
};
class Base2:virtual public Base
{
public:
Base2(int i, int j=0):Base(j){cout <<i;}
~Base2(){} };
class Derived:public Base2, public Base1
{
public:
Derived(int a, int b, int c, int d ):mem1(a), mem2(b), Base1(c), Base2(d), Base(a)
{cout << b;}
private:
Base2 mem2;
Base1 mem1;
}; void _tmain(int argc, _TCHAR* argv[])
{
Derived objD(1, 2, 3, 4);
int i;
cin >> i;
}

这一题考查了派生类的构造函数、多重继承和虚基类的概念。

概念一:关于初始化,派生类在初始化时一定会调用基类的构造函数,除非基类有默认构造函数(无参数或者参数有默认值)。其一般形式为“DerivedClass(ParaList):BaseClass(ParaList){Initialization Statement}”;

概念二:执行派生类构造函数的顺序为(析构函数与之相反),基类构造函数->子对象构造函数(多个子对象按照声明先后初始化)->派生类构造函数;

概念三:关于多重继承,声明派生类时,基类的出现顺序决定了构造函数的调用顺序;派生类只负责对其直接基类进行初始化,间接基类则自有相应的直接基类去初始化,虚基类除外;

概念四:关于虚基类,派生类不仅要对直接基类初始化,还要对虚基类进行初始化。C++保证了虚基类不会被多次初始化,且只会被派生类继承一次(避免成员重复);

根据以上概念可以容易的得出正确答案,C。

第二题  若数据元素序列 10,11,12,5,6,7,20,2,2 是采用下列排序算法之一得到的第二题排序后的结果,则该排序算法只能是

A 冒泡排序

B 选择排序

C 二路归并排序

D 插入排序

04-24 17:41