2015 Tencent 线上模拟测试题

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

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 插入排序

posted @ 2017-04-19 20:19  唐世光  阅读(322)  评论(0编辑  收藏  举报
友情链接:回力旗舰店 | 中老年高档女装 | 武汉英语培训 | 自学英语 | 成人零基础学英语