全国计算机等级考试二级C++笔试历年真题_第1页
全国计算机等级考试二级C++笔试历年真题_第2页
全国计算机等级考试二级C++笔试历年真题_第3页
全国计算机等级考试二级C++笔试历年真题_第4页
已阅读5页,还剩116页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

2006年9月考试真题(第24次).从工程管理角度,软件设计般分为两步完成,它们是.A、概要设计与详细设计B、过程控制C、软件结构设计与数据设计D、程序设计与数据设计从工程管理角度看,软件设计分为两步完成:概要设计与详细设计。概要设计(又称结构设计)将软件需求转化为软件体系结构、确定系统级接口、全局数据结构或数据库模式;详细设计确立每个模块的实现算法和局部数据结构,用适当方法表示算法和数据结构的细节.故本题答案为A。.数据库技术的根本目标是解决数据的.A、存储问题B、共享问题C、安全问题D、保护问题由于数据的集成性使得数据可为多个应用所共享,特别是在网络发达的今大,数据库与网络的结合扩大了数据关系的应用范用。数据的共享本身又“I极大地减少数据冗余性,不仅减少了不必要的存储空间,更为重要的是可以避免数据的不致性。因此,数据库设计的根本目标是要解决数据共享问题。故本题答案为B。.在数据库系统中,用户所见数据模式为.A、概念模式B、外模式C、内模式D、物理模式数据库管理系统的三级模式结构III外模式、模式和内模式组成。外模式又称为子模式,或用户模式,是指数据库用户所看到的数据结构,是用户看到的数据视图。模式又称为逻辑模式,是数据库中对全体数据的逻辑结构和特性的描述,是所有用户所见到的数据视图的总和。外模式是模式的一部分.内模式又称为存储模式或物理模式,是指数据在数据库系统内的存储介质匕的表示,即时数据的物理结构和存取方式的描述。故本题答案为B。.在长度为64的有序线性表中进行顺序查找,最坏情况下需耍比较的次数为 。A、63B、64C、6D、7在进行顺序查找过程中,如果线性表中的第1个元素就是被查找元索,则只需做一次比较就查找成功,杏找效率最高;但如果被春找的元素是线性表中的最后一个元素,或者被杳找的元索根本就不在线性衣中,则为/音找这个元素需要5线性衣中所有的元素进行比较,这是顺序有找的最坏情况。所以对长度为n的线性表进行顺序查找,在最坏情况下需要比较n次. 故本题答案为B。.对下列二叉树进行中序遍历的结果是.A、ACBDFEGB、ACBDFGEC,ABDCGEFD、FCADBEG二叉树的中序遍历指在访问根结点、遍历左子树与遍历右子树这三者中,首先遍历左子树,然后访问根结点,最后遍历右子树;并且遍历左、右子树时,仍然先遍历左子树,然后访问根结点,最后遍历右子树。故本题答案为A。.卜.列选项中不属于软件生命周期开发阶段任务的是.A、软件测试 B、概要设计 C、软件维护 D,详细设计软件生命周期分为软件定义、软件开发及软件维护。其中软件开发阶段的任务中软件设计阶段可分解成概要设计阶段和详细设计阶段:软件维护不属于软件开发阶段。 故木题答案为C。.下列叙述中正确的是。A、一个算法的空间复杂度大,则其时间复杂度也必定大B、一个算法的空间复杂度大,则其时间复杂度必定小C、一个算法的时间复杂度大,则其空间复杂度必定小D、上述三种说法都不对算法的复杂度主要包括时间复杂度和空间复杂度:算法在运行过程中需辅助存储空间的大小称为算法的空间复杂度:尊法的时间复杂度是指执行算法所需要的计算工作鼠,即算法执行过程中所需要的基本运算次数,为了能够比较客观地反映出一个算法的效率,在度量一个算法的工作量时,不仅应该与所使用的计算机、程序设计语言以及程序编制者无关,而且还应该与算法实现过程中的许多细节无关。为此,可以用算法在执行过程中所需基本运算的执行次数来度量算法的工作量.故本题答案为D。8.5列选项中不符合良好程序设计风格的是.A、源程序要文档化 B、数据说明的次序耍规范化C、避免滥用goto语句D、模块设计要保证高耦合、高内聚良好的程序设计风格可以使程序结构清晰合理,使程序代码便于维护,因此,程序设计风格对保证程序的质量很重要。主要应注意和考虑卜,述一些因素:1、源程序要文档化:2、数据说明的次序要规范化;3、语句的结构应该简单直接,不应该为提高效率而把语句发杂化,避免滥用got。语句•模块设计要保证低耦合、高内聚。 故本题答案为D。.设有如下三个关系表故本题答案为C。.数据库设计的四个阶段是:需求分析、概念设计、逻辑设计和 二A、编码设计 B、测试阶段 C、运行阶段 D、物理设计数据库设计分为以卜6个设计阶段:需求分析阶段、概念设计阶段、逻辑设计阶段、物理设计阶段、实施阶段及数据库运行和维护阶段。 故本题答案为及.下列运算符不能重载为友元函数的是A,=()[]->B、+-++—C,><>=<=D、+=-=*=/=本题考查的是运算符的取载。在C++中,可以通过两种方式对运算符进行重载。--种是类成员函数的方式、一种是友元函数的方式。=0口->以及所有的类型转换运算符只能作为成员函数重载,不能重载为友元函数。 故本题答案为A。.语句ofstreamf("SALARY.DAT",ios_base::app);的功能是建立流对象f,并试图打开文件SALARY.DAT与f关联,而且.A、若文件存在,将其置为空文件;若文件不存在,打开失败B,若文件存在,将文件指针定位于文件尾:若文件不存在,建立一个新文件C、若文件存在,将文件指针定位于文件首;若文件不存在,打开失败D、若文件存在,打开失败;若文件不存在,建立一个新文件

本题考查的是文件流的输出。ofstreamf("SALARY.DAT",iosbase::app);是以iosbase::app方式打开文件,若文件存在,将文件指针定位于文件尾:若文件不存在,建立一个新文件。 故木题答案为B。.有如下程序#include<iostream>usingnamespacestd;classApublic:virtualvoidfund(){cout«,,AlM;}{cout«nA2M{cout«nA2M;}{cout«MBr,;){cout«HB2H;)classB:publicA{public:voidfund()voidfunc2()};intmain()(A*p=newB;p->funcl();p->func2();return0;)运行此程序,屏幕上将显示输出OA、B1B2B、A1A2C、B1A2D、A1B2本题考查的是派生类。派生类B由菸类A公有继承而来。调用p->funcl();后,执行派生类B的函数voidfunclO:调用p-”unc2();后,执行基类的困数voidfunc2(),因为虚拟函数是根据对象的实际类型调用,非虚拟函数是根据指针类型调用。故通过指针p调用func2时将直接调用基类中的voidfunc2()。 故本题答案为C。.if语句的语法格式可描述为:格式1:if《条件>)<语句>或 格式2:if(<条件>)<语句l>else<语句2>关于上面的语法格式,下列表述中错误的是0A、〈条件>部分可以是一个if语句,例如if(if(a==0)…)…B、〈语句>部分可以是一个if语句,例如if(…)if(…)…C、如果在〈条件>前加上逻辑非运算符!并交换〈语句1>和〈语句2>的位置,语句功能不变D、〈语句>部分可以是一个循环语句,例如if(…)while(…)•••本题考查的是if语句.if为美键字,(条件》通常是一个表达式;if子句和else子句可以是任何类型的语句,当然也可以是if…else语句本身和while语句.if…else语句的基本执行过程是:首先计算〈条件》的值,如果此值不为0("真”),则执行〈语句1>,然

后忽略<语句2>,而去执行if语句之后的下•条语句;如果此值为0("假”),则执行〈语句2>,然后忽略<语句1》,然后继续执行if语句之后的下一条语句。 故木题答案为A。.下列语句中,错误的是。A、constintbuffer=256; B、constdouble*point;C、intconstbuffer=256; D、double*constpoint;本题考查的是符号常量定义。constintbuffer=256;〃声明常量bufferconstdouble*point; 〃声明常量指针*point,*point不可变,但point的值可以改变intconstbuffer=256;〃声明常量bufferdouble*constpoint; 〃声明的point是常量,*point可变,但point的值不可以改变,point不是外部的,必须在声明初始化常量对象。可改为:doubleaa=123.45;double*constpoint=&aa;故本题答案为D。.关于运算符重载,下列表述中正确的是oA、C++已有的任何运算符都可以重载B、运算符函数的返回类型不能声明为基本数据类型C、在类型转换符函数的定义中不需要声明返回类型D、可以通过运算符重载来创建C++中原来没有的运算符本题考查的是运算符重载。运算符重载是针对C++中原有的运算符进行的,不可能通过重载创造出新的运算符,故选项D错误。除了.、.*、->*、::、?:这5个运算符外,其它运算符都可以重载,故选项A错误。运算符函数的返回类型可以声明为基本数据类型,故选项B错误。在近载类型转换符时,由于运算符本身C经表示出返回值类型,因此不需要返回值类型的声明。 故本题答案为C。.关于在调用模板函数时模板实参的使用,卜.列叙述正确的是。A、对于虚拟类型参数所对应的模板实参,如果能从模板函数的实参中获得相同的信息,则都可以省略B、对于虚拟类型参数所对应的模板实参,如果他们是参数表中的最后的若干参数,则都可以省略C、对于虚拟类型参数所对应的模板实参,若能够省略则必须省略D、对于常规参数所对应的模板实参,任何情况下都不能省略本题考簧的是函数模板中模板实参的省略。对于虚拟类型参数所对应的模板实参,如果从模板函数的实参表中获得的信息已经能够判定其中部分或全部虚拟类型参数,而且它们又正好是参数表中最后的若干参数,则模板实参表中的那几个参数可以省略。反之,对于某个模板实参,如果从模板函数的实参表中无法获得相同的信息,就不能省略:或者虽然能够获得同样的信息,但在它后面还仃不能省略的实参,则其自身还是不能省略,故选项A和B错误。对于虚拟类型参数所对应的模板实参,若能够省略可以省略,也可以不省略,故选项C错误.常规参数的信息无法从模板函数的实参表中获得,因此在调用时必须显式的说明. 故本题答案为D。.若有下面的函数调用:fun(a+b,3,raax(n-1,b))则fun的实参个数是.A、3B、4C、5D、6本题考查的是函数的调用。在C++中,〈形参列表>是由逗号分开的,分别说明函数的各个参数。在fun()函数中它包括3个形参,a+b,3和mx(n-l,b);当调用一个函数时,实参与形参•对•地匹配,所以实参个数也是3个。故本题答案为A。

.下列有关内联函数的叙述中,正确的是。A、内联函数在调用时发生控制转移B、内联函数必须通过关键字inline来定义C、内联函数是通过编译器来实现的D、内联函数函数体的最后一条语句必须是return语句木题考查的是内联函数。在C++中使用inline关键字来定义内联函数。iniine关键字放在函数定义中函数类型之前。不过编译器会将在类的说明部分定义的任何函数都认定为内联函数,即使它们没有inline说明。一个内联函数可以有,也可以没有return语句。内联函数在程序执行时并不产生实际函数调用,而是在函数调用处将函数代码展开执行。内联函数是通过编译器来实现的。 故本题答案为C。.在公有继承的情况下,允许派生类直接访问的基类成员包括 一A、公有成员B、公有成员和保护成员C、公有成员、保护成员和私有成员D、保护成员本题考查的是派生类。派生类中的成员不能访问基类中的私有成员,可以访问基类中的公有成员和保护成员。此时派生类对基类中各成员的访问能力与继承方式无关,但继承方式将影响基类成员在派生类中的访问控制属性。故木题答案为B。.有如下程序:#include<iostream>usingnamespacestd;classObj{staticinti;public:ObjO{i++;}、Obj(){—;}staticintgetVal(){returni;});intObj::i=0;voidf(){Objob2;cout<<ob2.getVal();}intmain(){Objobi;f();0bj*ob3=newObj;cout<<ob3->getVal();deleteob3;cout<<Obj::getVal();return0;)程序的输出结果是。A、232B、231C、222D、221本题主要考查了C++中类的价态成员。由于i是类Obj的静态成员,该成员被类的所有实例共享。当定义obi时,系统自动调用构造函数Obj(),i的值将加1;调用函数£()时,在定义ob2时系统会自动调用构造函数Obj(),i的值将再加1;调用ob2.getVal();后,将i的值输出,输出值为2;当调用函数f()即将结束时,系统自动调用析构函数、Obj(),i的值将减1;当定义ob3时,系统自动调用构造函数Obj(),i的值将加1,调用cout〈<ob3->getVal0;后,将i的值输出,输出值为2;调用deleteob3后将执行Obj的析构函数、Ob_j(),执行后,i的值将减1,Obj::getVal()为类的一个静态成员函数,其作用是返回私有静态成员变量i的值1。 故本题答案为D。.下列有关继承和派生的叙述中,正确的是 .A、如果一个派生类私有继承其基类,则该派生类中的成员不能访问基类的保护成员B、派生类的成员函数可以访问基类的所有成员 C、基类对象可以赋值给派生类对象D、如果派生类没有实现基类的•个纯虚函数,则该派生类是•个抽象类.下列情况中,不会调用拷贝构造函数的是.A、用一个对象去初始化同一类的另一个新对象时B、将类的一个时象赋值给该类的另一个对象时C、函数的形参是类的对象,调用函数进行形参和实参结合时D、函数的返回值是类的对象,函数执行返回调用时本题考查的是拷贝构造函数。拷贝构造函数通常在以下3种情况下会被调用:(1)用类的一个已知的时象去初始化该类的另一个正在创建的对象。(2)采用传值调用方式时,对象作为函数实参传递给函数形参.(3)对象作为函数返回值。故本题答案为B。.有如下程序#include<iostream>#include<iomanip>usingnamespacestd;intmainO{cout<<setprecision(3)«fixed«setfill(**')<<setw(8);cout«12.345««34.567;return0;若程序的输出是: **12.345**34.567则程序中下划线处遗漏的操作符是oA、setprecisionB、fixedC、setfill('*')D、setw(8)本题考杏的是输入输出宽度的控制和输出精度的控制。setw(intn);设置输入输出的宽度。setprecision(intn);设置浮点数的精度(有效位数或小数位数)。setfill(charc);设置填充字符。由程序可以看出,本题设置小数的输出宽度为8,小数位数为3。输出数据时,如果数据宽度小于8,则空闲的位置用*填充。 故本题答案为D。.有如下的运算符重载函数定义:doubleoperator+(inti,intk){returndouble(i+k);}但定义有错误,对这个错误最准确的描述是OA、+只能作为成员函数重载,而这里的+是作为非成员函数重载的B、两个int型参数的和也应该是int型,而这里将+的返回类型声明为doubleC、没有将运算符重载函数声明为某个类的友元D、C++已经提供了求两个int型数据之和的运算符+,不能再定义同样的运算符本题考查的是运算符的重载。在C++中可以对用户自定义类的运算符进行重载,但不能诸如int,char,double等内置类型运算符进行重载。 故本题答案为D。.有如下程序#include<iostream>usingnamespacestd;classBase{protected:BaseO{cout«*A*;}Base(charc){cout«c;)};classDerived:publicBase{public:Derived(charc){cout<<c;}};intmain(){Deriveddl(B);return0;}执行这个程序屏幕上将显示输出。A、BB、BAC、ABD、BB木题考查的是派生的构造函数和基类的构造函数的调用顺序。建立.派生类对象时,构造函数的执行顺序如卜.:(1)执行基类的构造函数。(2)执行成员对象的构造函数。(3)执行派生类的构造函数。派生类Derived由基类Base公有派生而来。在派生类构造函数声明时系统会自动调用基类的缺省构造函数。调用Deriveddl(B);后,执行类Derived的构造函数的Derived(charc)定义,系统会自动调用基类的缺省构造函数BaseO,输出字母A:再执行派生类的构造函数Derived(charc),输出字母B。故本题答案为C。.关于关键字class和lypename,卜列表述中正确的是。A、程序中的typename都可以替换为class B、程序中的class都可以替换为typenameC、在模板形参表中只能用typename来声明参数的类型D、在模板形参表中只能用class或typename来声明参数的类型本题考查的是模板形参。模板形参分为两种类型:虚拟类型参数和常规参数。虚拟类型参数须用lypename或class定义。常规参数用具体的类型修饰符(如int、double、char*等)定义,故选项C和D错误。在定义模板时,关键字typename与class可以互相交换,但在定义类时,只能使用class。typename仅仅用于定义模板,故程序中所有的typename都可以替换成class,但对于用于类定义的class不能使用typename来替换。 故本题答案为A。.在一个派生类对象结束其生命周期时 。A、先调用派生类的析构函数后调用基类的析构函数B、先调用基类的析构函数后调用派生类的析构函数C、如果基类没有定义析构函数,则只调用派生类的析构函数D、如果派生类没有定义析构函数,则只调用基类的析构函数本题考查的是派生类析构函数的执行顺序。当主函数结束时,派生类析构函数的执行顺序是:先执行派生类的析构函数,再执行成员对象的析构函数,最后执行基类的析构函数。 故本题答案为A。.有如下类定义:classMyBase{

intk;public:MyBase(intn=0):k(n){}intvalue()const{returnk;}};classMyDerived:MyBase{intj;public:MyDerived(inti):j(i){}intgetKOconst{returnk;}intgetjOconst{returnj;});编译时发现有•处语法错误,对这个错误最准确的描述是. 。A、函数getK试图访问基类的私有成员变量kB、在类MyDerived的定义中,基类名MyBase前缺少关键字public、protected或privateC、类MyDerived缺少一个无参的构造函数D、类MyDerived的构造函数没有对基类数据成员k进行初始化本题考在的是派生类访问权限。在个派生类中,其成员由两部分构成:•部分是从基类继承得到的,另部分是自己定义的新成员,所有这些成员仍然分为公有、私有和保护三种访问属性。其中,从基类继承下来的全部成员构成派生类的基类部分,这部分的私有成员是派生类不能宜接访问的,公有成员和保护成员则是派生类可以直接访问的。故本题答案为A。.有如下程序#include<iostream>#include<iomanip>usingnamespacestd;classMyClass{ public:MyClass(){cout<<*A,;}MyClass(charc){cout«c;}'MyClassOfcout«'B';}};intmain(){MyClasspl,*p2; p2=newMyClass(*X*);deletep2;return0;}执行这个程序屏幕上将显示输出oA、ABXB、ABXBC、AXBD、AXBB本题考查的是析构函数和构造函数。在定义对象P1时由系统自动调用构造函数MyClass。,输出字母A:用new创建单个对象MyClass(X)时,要根据参数调用相应的构造函数MyClass(charc),输出字母X;在执行delete时,系统会自动调用析构函数、MyClass。,输出字母B,当对象的生存周期即将结束时系统会自动调用析构函数、MyClass(),输出字母Bo 故本题答案为D。.以下关键字不能用来声明类的访问权限的是oA、publicB、staticC、protectedD、private本题考查的是类的定义。类定义的一般格式如下:class〈类名〉(public:〈成员函数或数据成员的说明》〃公有成员,外部接口〈成员函数或数据成员的说明》〃公有成员,外部接口protected:<数据成员或成员函数的说明〉 〃保护成员private:〈数据成员或成员函数的说明) 〃私有成员};关键字public、private和protected称为访问权限修饰符,他们限制了类成员的访问控制范围。故本题答案为B。.有如下程序#include<iostream>usingnamespacestd;inti=l;classFun(pubIic:staticinti;intvalue0{returni_l;}intvalue()const{returni+1;}};intFun::i=2;intmain(){inti=3;Funfunl;constFunfun2;return0;)若程序的输出结果是:123则程序中下划线处遗漏的语句是OA、cout«funl.value()«Fun::i«fun2.valueO;B、cout«Fun::i<<funl.value0«fun2.valueO;C、cout«funl.value()«fun2.value()«Fun::i;D、cout«fun2.value()«Fun::i<<funl.value();本题主要考查了常对象的•些概念。由于i是类Fun的邮态成员,该成员被类的所有实例共享。对于类中的静态成员函数,可以通过“类名::函数名”的方法来调用,并且该函数只能访问类中的峥态成员。在C++中,对于常对象的成员函数调用,将自动调用其常成员函数。在本题中执行funl.value。,将调用原型为"intvalue。;”的函数,i的值返回1;执行fun2.value。;,将调用原型为"intvalue()const;"的函数,i的值返何3;执行Fun::i时,调用类的静态成员i,i的值返回2。 故本题答案为A。.有如下说明inta[10]={l,2,3,4,5,6,7,8,9,10},*p=a;则数值为9的表达式是。A、*p+9B、*(p+8)C、*p+=9D、p+8本题考查的是指针与数组。数组的下标是从0到数组的长度减1。*(p+i)是取数组的第i+1个元素,即下标为i的元素。因此*(p+8)

取数组的第9个元素,即元素9。 故本题答案为B..下列符号中,正确的C++标识符是.A、enumB、2bC、foo-9D,32本题考查的是标识符。标识符是一个以字母或卜划线开头的,由字母、数字、卜划线组成的字符串。标识符不能与任意一个关键字同名. 故本题答案为D。.下列关于输入流类成员函数getlineO的描述中,错误的是.A,该函数是用来读取键盘输入的字符串的 B、该函数读取的字符串长度是受限制的C、该函数读取字符串时,遇到终止符便停止D、该函数读取字符串时,可以包含空格本题考查的是文件流的输入输出。函数getline(char_type*s,streamsizen,char_typedelim)的作用是从当前位置开始提取字符存入s所指向的具有n各字节的字符空间。字符的提取与存储在遇到卜列情况时停止:(1)已提取并存储了nT个字符;(2)到流尾,无字符可提取;(3)下一个要提取的字符等于结束标志delim.故本题答案为B。.按"先进后出"原则组织数据的数据结构是o标准答案为:栈栈和队列都是一种特殊的操作受限的线性表,只允许在端点处进行插入和删除。:者的区别是:栈只允许在表的一端进行插入或删除操作,是种“先进后出''的线性表;而队列只允许在表的端进行插入操作,在另一端进行删除操作,是一种“先进先出”的线性表。.下列软件系统结构图的宽度为。标准答案为:3或三软件系统结构图的宽度:整体控制跨度(最大模块数的层)的表示..的任务是诊断和改正程序中的错误。标准答案为:程序调试或调试程序:调试的任务是诊断和改正程序中的错误。它与软件测试不同,软件测试是尽可能多地发现软件中的错误。先要发现软件的错误,然后借助于一定的调试工具去找出软件错误的具体位置。软件测试贯穿整个软件生命期,调试主要在开发阶段。.一个关系表的行称为。标准答案为:元组或记录设计数据库的目的实质上是设计出满足实际应用需求的实际关系模型;关系中的行称为元组,对应存储文件中的记录,关系中的列称为属性,对应存储文件中的字段。.数据结构分为线性结构和非线性结构,带链的队列属丁。标准答案为:线性结构与栈类似,队列也是线性表,也可以采用链式存储结构。.创建对象数组时,对数组的每一个元素都将调用一次构造函数,如果没有显式给出数组元素的初值,

则调用缺省构造函数。下列程序涉及到对象数组的创建和单个对象的创建,其输出结果是一 一。#include<iostream>usingnamespacestd;classFoo{public:Foo(intx){cout«,A);}Foo(){}};intmainO(Foof[3],g(3);return0;)标准答案为:A木题考查的是类的对象数组和成员对象。从程序可以看出f[3]是类Foo的一个对象数组,因为f[3]没有显式的给定初值,所以系统自动调用缺省构造函数Foo():在定义类Foo的对象g(3)时,执行相应的构造函数Foo(intx),输出字母A。.插入排序算法的主要思想是:每次从未排序序列中取出的一个数据,插入到已排序序列中的正确位置。InserlSort类的成员函数sort。实现了插入排序算法。请将画线处缺失的部分补充完整。classInsertSort{public:InsertSort(int*aO,intnO):a(a0),n(n0){}//参数aO是某数组首地址,n是数组元素个数voidsort0{〃此函数假设已排序序列初始化状态只包含a[0],未排序序列初始为a[l]…a[nT]for(inti=l;i<n;++i){intt=a[i];intj;for(;j>0;-j){if(t>=a[j-l])break;a[j]=a[j-l];}a[j]=t;}}protected:int*a,n;〃指针a用于存放数组首地址,n用于存放数组元素个数);标准答案为:j=i本题考查的是插入排序。在Sort函数中,实现函数的插入排序算法,若队列中已有i个数,则向其中插入第i+1个数时,依次与从下标为iT到下标为0的数比较,如果后面的数小于前面的数,则交换这两个数,否则说明该数已排好序,直接跳出内层循环,故此空应填j=i。.如果不使用多态机制,那么通过基类的指针虽然可以指向派生类对象,但是只能访问从基类继承的成员。下列程序没有使用多态机制,其输出结果是.#include<iostream>usingnamespacestd;classBase{publie:voidprintO{cout<<'B';}};classDerived:publicBase{public:voidprint(){cout«,D*;}};intmain()(Derived*pd=newDerivedO;Base*pb=pd;pb->print();pd->print();deletepd;return0;)标准答案为:BD本题考查的是派生类。派生类Derived由基类Base公有继承而来,是基类的子类型.调用pb->print();后,执行基类的函数voidprint。,因为尽管pb的函数print。可以对类Base的公有派生类Derived的对象pd进行操作,但是只能使用从基类Base中继承的成员;调用pd->print();后,执行派生类的函数voidprintO..若有定义语句:int*a,b;,则变量b的数据类型是.标准答案为:整型或int本题考查的是变量的定义.int*a,b;把a定义为一个int类型的指针:把b定义为一个整型变量。.在声明派生类时,如果不显式地给出继承方式,缺省的类继承方式是私有继承private。已知有如下类定义:classeBase{protected:voidfun(){}};classDerived:Base{};则Base类中的成员函数fun(),在Derived类中的访问权限是。(注意:要求填写private、protected或public中的一项)。标准答案为:private.下列程序的输出结果是o#include<iostream>usingnamespacestd;classA{inta;publie:A():a(9){}virtualvoidprint()const{cout<<a:};};classB:publieA{charb;publie:B(){b='S';}voidprintOconst{cout«b;)};voidshow(A&x){x.print();}intmain(){Adl,*p;B62;p=&d2;dl.printO:d2.printO;p->print();show(dl);show(d2);return0;)标准答案为:9SS9S本题主要考杏了缺省构造函数。在dl、d2定义时分别调用它们的构造函数。调用dl.print。;后,执行类A的virtualvoidprintO函数;调用d2.printO;后,执行派生类B的构造函数voidprint(生调用p->print();后,执行执行派生类B的构造函数voidprint0:调用show(dl);后,调用函数sho*(A&x),再调用类A的virtualvoidprint0函数:调用show(d2);后,调用函数show(A&x),再调用派生类B的构造函数voidprintO..已知递归函数f的定义如下:intf(intn){if(n<=l)return1;〃递归结束情况elsereturnn*f(n-2);〃递归}则函数调用语句f(5)的返回值是 。标准答案为:15本题主要考查了递力算法。函数每次将f(n)的值转换成相应的关系式n*f(n-2),直到f(l)时为止。所以f(5)=5*f(5-2)=5*3*f(1)=5*3*1=15..已知数组a中的元素个数为n,卜一列语句的作用是将卜一标为i的元素移动到卜标为i-1的单元,其中K=i<no例如,当n=4,a中原有的数据为1,2,3,4时,则移动后a中元素变为2,3,4,4。请将语句补充兀%:for(inti=0;i<n-l;i++)a[i]=a[];标准答案为:i+1或1+1本题考查循环的基本应用.解题思路为:循环条件是循环的结果是把将下标为i的元素移动到下标为iT的单元,即a[i+l]的值赋给a[i],所以答案是i+L.己知下列程序的输出结果是42,请将画线处缺失的部分补充完整。#include<iostream>usingnamespacestd;classFoo{intvalue;public:Foo0:value(0){}voidsetValue(intvalue){=value;} 〃给Foo的数据成员value赋值voidprint(){cout«value;});intmain()(Foof;f.setValue(42);f.print();return0;)标准答案为:this->value或Foo::value或(*this).value本题考查的是this指针。this指针,它是成员函数的所属对象的指针,它指向类对象的地址。本题要输出42,也就是要把f.setValue(42);中的42赋值给Foo的数据成员value,因此横线处缺少的是给Foo的数据成员value赋值的语句,所以答案为this->value或Foo::value。50.在MyClass类的定义中,对赋值运算符二进行重载。请将画线处缺失的部分补充完整。MyClass::operator=(constMyClass&rhs)(if(this==&rhs)return*this;value=rhs.value;return*this;)标准答案为:MyClass&本题考查的是运算符的重载。一个类如果要重载运算符。通常也就需要定义自己特有的拷贝构造函数。可以在类体中增加:(const&operatorMyClassArhs);然后在MyClass的类体外给出它的完整定义:MyClass&MyClass::operator=(constMyClass&rhs){……}因此在MyClass类的定义中缺少MyClass&语句。2007年4月考试真题(第25次).下列叙述中正确的是。A、算法的效率只与问题的规模有关,而与数据的存储结构无关B、算法的时间复杂度是指执行算法所需要的计算工作量C、数据的逻辑结构与存储结构是一一对应的D,算法的时间复杂度与空间复杂度一定相关我们通常用时间复杂度和空间复杂度来衡量算法效率,嵬法的时间复杂度是指执行算法所需要的计算工作鼠;算法所执行的基本运算次数与问题的规模有关,而一个算法的空间复杂度,一般是指执行这个算法所需要的内存空间;一般来说,一种数据的逻辑结构根据需要可以表示成多种存储结构。故本题答案为B。2.对下列二叉树

A进行前序遍历的结果为A、DYBEAFCZXB、YDEBFZXCAC、ABDYECFXZD、ABCDEFXYZ在先左后右的原则下,根据访问根结点的次序,二义树的遍历可以分为3种:前序遍历、中序遍历和后序遍历。前序遍历是指在访问根结点、遍历左子树与遍历右子树这三者中,首先访问根结点,然后遍历左子树,最后遍历右子树;并且遍历左、右子树时,仍然先访问根结点,然后遍历左子树,最后遍历右子树。 故本题答案为C。.下列叙述中正确的是.A,软件测试的主要目的是发现程序中的错误B、软件测试的主要目的是确定程序中错误的位置C、为了提高软件测试的效率,最好由程序编制者自己来完成软件测试的工作D、软件测试是证明软件没有错误关于软件测试的目的,GrenfordJ.Myers在(TheArtofSoftwareTesting》一书中给出了深刻的阐述:软件测试是为了发现错误而执行程序的过程:一个好的测试用例是指很可能找到迄今为止尚未发现的错误的用例;一个成功的测试是发现了至今尚未发现的错误的测试。整体来说,软件测试的目的就是尽可能多地发现程序中的错误。故本题答案为A。.某二叉树中有n个度为2的结点,则该二叉树中的叶子结点数为.A、n+1B、n-1C、2nD、n/2二叉树的性质3:在任意-•棵二叉树中,度为0的结点(即叶子结点)总是比度为2的结点多一个。木题中度为2的结点数为n,故叶子结点数为n+1个.故本题答案为A..下面选项中不属于面向对象程序设计特征的是.A,继承性B、多态性C、类比性D、封装性对象是由数据和容许的操作组成的封装体,与客观实体有直接的对应关系。对象之间通过传递消息互相联系,以模拟现实世界中不同事物彼此之间的联系。面向对象技术有三个重要特性,封装性、继承性和多态性。故本题答案为C。.下列对队列的叙述正确的是.A、队列属于非线性表 B、队列按"先进后出”原则组织数据C、队列在队尾删除数据 D、队列按"先进先出”原则组织数据队列是指允许在端进行插入、而在另•端进行删除的线性表,允许插入的端称为队尾,允许删除的端称为队头.它乂称为“先进先出"或"后进后出”的线性表,体现了"先来先服务”的原则。故本题答案为D。7.在结构化程序设计中,模块划分的原则是 。A、各模块应包括尽量多的功能 B、各模块的规模应尽量大C、各模块之间的联系应尽量紧密 D、模块内具有高内聚度、模块间具有低耦合度软件设计中通常采用结构化设计方法,模块的独立程度是评价设计好坏的重要度量标准。耦合性与内聚性是模块独立性的两个定性标准。内聚性是•个模块内部各个元素间彼此结合的紧密程度的度量;耦合性是

模块间互相连接的紧密程度的度量。一般较优秀的软件设计,应尽量做到高内聚,低耦合,即减弱模块之间的耦合性和提高模块内的内聚性,有利了提高模块的独立性。故木题答案为D。.下列叙述中错误的是.A、在数据库系统中,数据的物理结构必须与逻辑结构一致B、数据库技术的根本目标是要解决数据的共享问题C、数据库设计是指在已有数据库管理系统的基础上建立数据库D、数据库系统需要操作系统的支持数据库系统具有数据独立性的特点,数据独立性一般分为物理独立性与逻辑独立性两级。物理独立性即是数据的物理结构的改变都不影响数据库的逻辑结构;逻辑独立性即数据库总体逻辑结构的改变,不需要相应修改应用程序。所以,在数据系统中,数据的物理结构并不一定与逻辑结构一致。故本题答案为A。.在E-R图中,用来表示实体之间联系的图形是A、矩形B、椭圆形C、菱形D、平行四边形E-R图中用矩形发示实体集,用椭圆表示属性,用菱形发示联系。故本题答案为C。.在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是 一。A、并B、交C、投影D、笛卡儿乘积对关系数据库进行查询时,需要找到用户感兴趣的数据,这就需要对关系进行一定的关系运算。关系的基本运算有两类:一类是传统的集合运算(并、交、差),另一类是专门的美系运算(选择、投影、连接).集合的并、交、差:设有两个关系R和S,它们具有相同的结构,R和S的并是由属于R和S,或者同时属于R和S的所有元组成的集合,记作RUS;R和S的交是由既属于R又属于S的所有元组组成的集合,记作RCS;R和$的差是由属于R但不属于S的所有元组组成的集合,记作R-S.故本题答案为B。.有如下程序段:inti=0,j=l:TOC\o"1-5"\h\zint&r=i: // ①r=j: // ②int*p=&i; //③*p=&r; // ④其中会产生编译错误的语句是.A、④B、③C、②D、①本题考查的是引用。&r是指一个指向整型变鼠的地址,p为一个指向整型变最的指针,*p则是一个整型变量,将地址赋值给整型变量是非法的。故本题答案为A。.使用输入输出操作符setw,可以控制.A、输出精度 B、输出宽度C、对齐方式D、填充字符本题考查的是输入输出操作符。使用输入输出操作符setw,可以控制输入输出宽度。故本题答案为B..若有如下类声明classMyClass{public:MyClassO{cout«l;}};执行下列语句MyClassa,b[2],*p[2];以后,程序的输出结果是.a、iib、inc、mid、mu本题考查的是对象数组。"MyClassa,b[2],*p[2]执行时,将初始化一个变量名为a的MyClass实例,其为"1”,然后又初始化一个含有两个MyClass实例的数组,它将执行两次MyClass的构造函数,输出两个"1”,对于P,它是一个含有2个指向MyClass类型的指针,它不会调用MyClass的构造函数。故本题答案为B。.有如下函数模板:template<classT>Tsquare(Tx){returnx*x;}其中T是oA、函数形参B、函数实参C、模板形参 D、模板实参本题考查的是函数模板格式。声明一个函数模板格式是:template”模板形参表声明>〉《函数声明》其中<模板形参表声明》是由一个或多个〈模板形参)组成(如果是多个需要用逗号隔开)。每个<模板形参》具有卜.面几种形式:(l)lypename<参数名>(2)class(参数名〉(3)〈类型修饰〉〈参数名〉这里的<参数名》可以是任意的标识符。故本题答案为C。.有如下程序:#include<iostream>usingnamespacestd;classtest{private:inta;publie:test(){cout<<l,constructorH«endl;}test(inta){cout«a<<endl;}test(consttest&_test){a=_test.a;cout<<McopyconstruetorH«endl;}-test(){cout«**destructorM«endl;}};intmain(){testA(3);return0;)运行时输出的结果是oA、3constructordestructorcopyconstructordestructorD、3destructor本题考查的是构造函数和析构函数。"testA(3);”利用整数3来初始化类型A的实例,它将调用构造函数test::test(inta);输出"3”,当主函数结束后,将执行A的析构函数,输出"destruetor"。故本题答案为D。.通过运算符重载,可以改变运算符原有的」A、操作数类型 B、操作数个数C、优先级D、结合性本题考查的是重载运算符.C++允许重载运算符,在重载运算符时,不能改变操作数的个数,优先级,结合性,但可以改变操作数的类型,但对于有些运算符是不允许重载的,如":等,有些则不建议重裁,如等。故本题答案为A。.执行下列语句段后,输出字符"*"的个数是 .for(inti=50;i>l:—i)cout«A,48B、49C、50D、51本题考杏的是for循环语句。本程序的for语句中,循环控制变量i的初始值为50,条件表达式"i〉l"规定当i的值大于1时重复执行循环体;"一i”我示每循环次i的值减1。当i等于1的时候终止循环,此时循环次数为49次。故本题答案为B。.在语句cin>>data;中,cin是。A、C++的关键字 B、类名C、对象名D、函数名本题考查的是基本输入/输出流对象。C++程序的输入输出操作是通过标准库中的输入/输出流对象来完成的。在头文件iostream中定义了代表屏幕的标准输出流对象coin和代表键盘的标准输入流对象cin。由此可知cin是一个ioslream类型的对象。故本题答案为C。.有如下程序:#include<iostream>usingnamespacestd;intmainO{charstr[100],*p;cout«"Pleaseinputastring:";cin>>str;p=str;for(inti=0;*p!='\0,;p++,i++);cout«i<<endl;return0;)运行这个程序时,若输入字符串为abedefgabed则输出结果是。A、7B、12C、13D、100本题考杳的是流对象。在采用cin输入字符串时,将以空格分割各字符串,因此在输入"abedefgabce”,只耨"abedefg”赋值给str,而下面for循环的目的是计算该字符串的长度,不难得出该字符的长度为7。故本题答案为A..卜列关于派生类构造函数和析构函数的说法中,错误的是 .A、派生类的构造函数会隐含调用基类的构造函数B、如果基类中没有缺省构造函数,那么派生类必须定义构造函数C、在建立派生类对象时,先调用基类的构造函数,再调用派生类的构造函数D、在销毁派生类对象时,先调用基类的析构函数,再调用派生类的析构函数本题考查的是派生类构造函数和析构函数。在派生类实例化时,派生类的构造函数将隐式调用基类的构造函数,完成基类的初始化,如果基类没有缺省构造函数,派生类必须显式定义构造函数,以使得基类能够调用基类的构造函数,以完成基类的初始化,在对象销毁时,将首先执行派生类的析构函数,然后执行基类的析构函数。故本题答案为D。.下列函数模板的定义中,合法的是.template<typenameT>Tabs(Tx){returnx<0?-x:x;}templateclass<T>Tabs(Tx){returnx<0?-x:x;}templateT<classT>abs(Tx){returnx<0?-x:x;}templateTabs(Tx){returnx<0?-x:x;}本题考查的是函数模板格式。声明一个函数模板格式是:template<〈模板形参表声明〉》〈函数声明)其中〈模板形参表声明》是由•个多多个〈模板形参〉组成(如果是多个需要用逗号隔开)。每个(模板形参〉具有下面几种形式:typename〈参数名)class〈参数名〉(3)〈类型修饰〉〈参数名〉这里的〈参数名〉可以是任意的标识符。 故本题答案为A..有如下程序:#include<iostream>usingnamespacestd;classPoint{public:staticintnumber;public:Point(){number++;}-Point(){number―;}};intPoint::number=0;voidmain(){Point*ptr;PointA,B;(Point*ptr_point=newPoint[3];ptr=ptr_point;)PointC;cout«Point::number<<endl;delete[]ptr;}运行时输出的结果是.A,3B、4C、6D、7本题考查的是对象数组与静态数据成员。在程序运行时,首先将静态变量初始化为0,当实例化A、B时,将执行两次构造函数,number的值将变为2,语句"ptr_point=newPoint[3]定义了•个长度为3的Point型数组,从而乂执行二次构造函数,number值为5,定义变量C时,再次执行Point的构造函数,最终number的值为6。 故木题答案为C.23.字面常量42、4.2、42L的数据类型分别是.A,long、double,intB、long,float,intC,int、double-,longD、int,float,long本题考杳的是数据类型。对于整型数,如不采用后缀说明符,默认为int类型,L表示长整型;对于浮点数,不加后缀标识符默认类型为double类型,对于单精度浮点数要加"F”后缀。 故本题答案为C..下列关于类定义的说法中,正确的是.A、类定义中包括数据成员和函数成员的声明B、类成员的缺省访问权限是保护的C、数据成员必须被声明为私有的D、成员函数只能在类体外进行定义本题考杳的是类的格式。类的定义格式•般地分为说明部分和实现部分。说明部分是用来说明该类中的成员,包含数据成员的说明和成员函数的说明。成员函数可以在类体外进行定义也可以在类体内进行。从访问权限上来分,类的成员又分为:公有的(public),私有的(private)和保护的(protected)三类。类成员的缺省访问权限是私有的. 故本题答案为A。.有如下函数定义:voidfunc(inta,int&b){a++;b++;}若执行代码段:intx=0,y=l;func(x,y):则变量x和y的值分别是 。A,0和1B、1和1C、0和2 D、1和2本题考查的是函数调用。本题中定义了一个func函数,当调用func(x,y);函数时,形参a和b被初始化为实参x和y的引用,参数a为非引用类型,参数b为引用类型,在执行该函数时,对形参a的改变不会影响到实参,形参b的改变将会影响到实参,因此调用func函数后,形参变量a=l,b=2,实参变量x=0,y=2。 故本题答案为C。26.虚函数支持多态调用,一个基类的指针可以指向派生类的对象,而且通过这样的指针调用虚函数时,被调用的是指针所指的实际对象的虚函数。而非函数不支持多态调用。有如下程序:#include<iostream>usingnamespacestd;classBase(public:virtualvoidf(){cout<<"f0+":}voidg(){cout«"g0+";});classDerived:publicBase{public:voidf(){cout«"f+":}voidg(){cout«"g+";}};intmain()Derivedd:Base*p=&d;p->f();p->g();return0;}运行时输出的结果是0A、f+g+B、f0+g+C、f+g0+D、f0+g0+本题考查的是多态与虚拟函数。Derived::f()在基类中被定义为虚拟函数,故在执行p->f()时,将根据该指针所指对象的实际类型调用成员函数,而P是指向一个Derived类型的指针,故在调用时,将调用Derived::f(),输出对于p->g(),由于g()没有被定义成虚拟函数,将直接依据指针类型调用该成员函数,p是一个Base类的指针,故将调用Base::g(),从而输出"g0+”,故本题输出为"f+gO+J故本题答案为C。.下面程序中对一维坐标点类Point进行运算符重载^include<iostream>usingnamespacestd;classPoint{public:Point(intval){x=val;}Point&operator++(){x++;return*this;}Pointoperator++(int){Pointold=*this;++(*this);returnold;)intGetX0const{returnx;}private:intx;);intmain()(Pointa(10);cout«(++a).GetX();cout«a++.GetX();return0;)编译和运行情况是OA、运行时输出1011B、运行时输出1111C、运行时输出1112D、编译有错本题考查的是运算符重载。 对于++,一运算符有前置与后置两种方式,在以成元函数方式重载该运算符时,对于前置运算符可以以通常的一元运算的方式进行重载,对于后置运算符,则需在参数列表中加一个辅助类型的参数,以便于前置运算符区别。本题的输出结果为1111。 故本题答案为B。.下列字符串中,不可以用作C++标识符的是。A、y_2006B、_TEST_H C、ReturnD、switch本题考查的是C++标识符。 C++标识符是用字母、数字、下划线组成的字符串。标识符不能与任何一个关键字同名,因此switch不能作为标识符。 故本题答案为D。30.有如下程序:#include<iostream>usingnamespacestd;classSample(friendlongfun(Samples);public:Sample(longa){x=a;}private:longx;};longfun(Samples){if(s.x<2)return1;returns.x*fun(Sample(s.xT));)intmain(){intsum=0;for(inti=0;i<6;i++){sum+=fun(Sample(i));}cout<<sum;return0;)运行时输出的结果是OA、120B、16C、154D、34本题考查的是友元函数。令funl(i)=fun(Sample(i));则i=0或i=l时,由于s.x<2,故funl(i)均返回1;当i>=2时,funl(i)=i*funl(i-l);故sum=funl(0)+funl(1)+funl(2)+funl(3)+funl(4)+funl(5)=1+l+2*funi(1)+3*funl(2)+4*funl(3)+5*funl(4)=0!+1!+2!+3!+4!+5!=1+1+2+6+24+120=154o 故本题答案为C。.如果不使用多态机制,那么通过基类的指针虽然可以指向派生类对象,但是只能访问从基类继承的成员。有如下程序,没有使用多态机制。#include<iostream>usingnamespacestd;classBase{inta,b;public:Base(intx,inty){a=x;b=y;}voidshow(){cout<<a«\*«b<<endl;});classDerived:publicBase{intc,d;public:Derived(intx,inty,intz,intm):Base(x,y){c=z;d=m;}voidshow(){cout<<c«\*«d<<endl;});intmain()(BaseBl(50,50),*pb;DerivedDI(10,20,30,40);pb=&Dl;pb->show();return0;}运行时输出的结果是oA、10,20B、30,40C、20,30D、50,50本题考查的是继承与多态。 由于函数show是非虚拟的,故其调用依据其指针类型决定,而pb是一个指向Base的指针,故在调用show时,将调用Base::show,输出成员变量a,b,而pb是指向变量D1的,D1在实例化时,将基类中a,b初始化为10、20,故木题的输出为10,20。故本题答案为A。.有如下程序:^include<iostream>usingnamespacestd;classA{public:staticinta;voidinitO{a=l;}A(inta=2){init0;a++;)};intA::a=0;Aobj;intmain(){cout<<obj.a;return0;}运行时输出的结果是OA、0B>1C、2D、3本题考查的是静态成员变量。由于定义了全局变量obj,它将导致执行A的构造函数,而A的构造函数调用了其成员函数init,该函数负责将成员变量(静态)初始化为1,对于语句,其a是指构造函数的形参a,而不是成员变量a,它不会影响类的静态成员值。 故本题答案为B。.有如下程序:#include<iostream>usingnamespacestd;classA{public:A(inti){x=i;}voiddispa(){cout<<x«private:intx;);classB:publicA{public:B(inti):A(i+10){x=i;}voiddispbO{dispa0;cout<<x«endl;}private:intx:);intmain()(Bb(2);b.dispbO;return0;}运行时输出的结果是OA、10,2B、12,10C、12,2D、2,2本题考查的是类的继承与实例化。"Bb(2):"以整数2实例化变量b,在执行B的构造函数时,以i+10即12去调用类B的父类的构造函数,从而将A::x初始化为12,然后将B::x赋值为2。在执行b.dispbO时,先调用了父类中dispa,输出A::x,即12,再输出B::x,即2,从而运行结果为"12,2"。 故本题答案为C。.下列有关继承和派生的叙述中,正确的是oA、派生类不能访问基类的保护成员 B、作为虚基类的类不能被实例化C、派生类应当向基类的构造函数传递参数 D、虚函数必须在派生类中市:新实现本题考查的是继承和派生。派生类可以访问基类中的保护、公有成员。当基类有默认构造函数时,派生类可以不必向某类传递参数,直接调用派生类的默认构造函数,仅纯虚函数必需要在非抽象的子类中实现,虚基类不能被实例化。故本题答案为B。.为了取代C中带参数的宏,在C++中使用.A、重载函数 B、内联函数 C、递归函数 D、友元函数本题考查的是内联函数。内联函数就是小型函数,牺牲空间来节省函数调用的开销,一般用作比较小的函数,即函数内部没有循环、开关语句等。内联函数被发明出来就是为了取代C中的宏。 故本题答案为B。.软件生命周期可分为多个阶段,一般分为定义阶段、开发阶段和维护阶段。编码和测试属于阶段。软件生命周期分为软件定义、软件开发及软件运行维护3个阶段。本题中软件编内和软件测试都属于软件开发阶段;维护是软件生命周期的最后个阶段,也是持续时间最长,花费代价最大的个阶段,软件工程学的一个目的就是提高软件的可维护性,降低维护的代价。.软件测试分为白箱(盒)测试和黑箱(盒)测试。等价类划分法属于测试。软件测试的方法有3种:动态测试、静态测试和正确性证明.设计测试实例的方法一般有两类:黑盒测试方法和白盒测试方法。黑盒测试方法主要有:等价类划分法、边界值分析法、错误推测法、因果图等,主要用于软件确认测试。

.在结构化分析使用的数据流图(DFD)中,利用对其中的图形元素进行确切解释。数据字典是结构化分析方法的核心。数据字典是对所有与系统相关的数据元素的一个有组织的列表,以及精确的、严格的定义,使得用户和系统分析员对了输入、输出、存储成分和中间计算结果有共同的理解。数据字典把不同的需求文档和分析模型紧密地结合在一起,与各模型的图形表示配合,能清楚地表达数据处理的要求。概括地说。数据字典的作用是对DFD中出现的被命名的图形元素的确切解释。.在深度为7的满:叉树中,度为2的结点个数为。所谓满二义树是指这样的•种二又树:除最后•层外,每层上的所有结点都有两个子结点.这就是说,在满二叉树中,每一层上的结点数都达到最大值,即在满二叉树的第K层上有2卜1个结点,且深度为m的满二叉树有2111T个结点。在满二叉树中,最后一层的结点个数就是叶子结点的个数,本题中深度为7,故叶子结点数为27-1=127,且第七层的叶子结点数为27T=64。由二叉树的性质3:在任意一棵二叉树中,度为0的结点(即叶子结点)总是比度为2的结点多一个,可知:本题中度为2的结点数为127-64=63个。.在数据库系统中,实现各种数据管理功能的核心软件称为。数据库管理系统是数据库的机构,它是一种系统软件,负责数据库中的数据组织、数据操纵、数据维护、控制及保护和数据服务等.数据库管理系统是数据库系统的核心。.已知一个函数的原型是:intfn(doublex);若要以5.27为实参调用该函数,应使用表达式o函数的调用形式为:<函数名)(<实参表))当调用一个函数时,其实参的个数、类型及排列次序必须与函数定义时的形参一致,也就是说实参与形参应该一对一地匹配。.有如下程序:#include<iostream>usingnamespacestd;classDA{intk;public:DA(intx=l):k(x){}〜DA(){cout«k;}};intmain(){DAd[]={DA(3),DA(3),DA(3)}:DA*p=newDA[2];delete[]p;return0;)这个程序的输出结果是°定义DA型数组d时,将导致DA的构造函数被执行三次,每次执行时,其传入参数为3,定义DA指针p时,将执行两次默认构函数,其参数为1,执行"delete[]p”时,将执行DA的构造函数,输出p[0].k,p[l].k(两者均为1),在程序运行结束后,将释放局部变量,从而导致数组d中的三个元素被析构,输出中的a值(均为3)。 标准答案为:11333.有如下程序:

#include<iostream>usingnamespacestd;classCA{public:CAO{cout«'A';});classCB:privateCA(public:CBO{cout«'B*;)};intmain(){CAa;CBb;return0;)这个程序的输出结果是O"CA语句将导致CA的构造函数被执行,输出"A","CAb;〃语句将导致CB的构造函数执行,由于CB私有继承CA,故在执行CB的构造函数前,先执行CA的构造函数,输出“A”,然后执行CB的构造函数,输出"B"。 标准答案为:AAB.用来派生新类的类称为,而派生出的新类称为它的子类或派生类。当类A继承自或派生于类B时,类B称为类A的基类或父类,类A称为类B的子类或派生类。.若要访问指针变量p所指向的数据,应使用表达式。本题考查的是指针的应用。 要访问一个指针所指向的数据,应该用*运算符。.C++中只有两个逻辑常量:true和。本题考查的是逻辑变量。 在C++中引进了两个逻辑变量,true与false。.如下类定义中包含了构造函数和拷贝构造函数的原型声明,请在横线处填写正确的内容,使拷贝构造函数的声明完整。classmyClass{private:intdata;public:myClass(intvalue);〃构造函数myClass(constanotherObject);〃拷贝构造函数}拷贝函数的参数必须为其所对应类的引用类型。要实现拷贝,首先要保证前后类型一致,其次,不能为非引用类型,否则将递归调用拷贝构造函数。 标准答案为:myClass&.若将一个二元运算符重载为类的成员函数,其形参个数应该是个。函数可以以成员函数与友元函数这两种不同的方式来重载。对于二元运算符来说,当采用成员函数方式重我时,其实参的第•个参数为该对象本身,即a.operatorx(b)等价于axb,当采用友元函数重载时,必须要具有两个参数。peratorx(a,b)等价于axb。(其中x表示运算符)。标准答案为:一或1.C++语言中的多态性分为编译时的多态性和时的多态性。C++的多态表现在编译时多态与运行时多态两个方面,所谓编译时多态是指源代码在编译时必须能够确定要执行的代码,如函数的重载,模板等,在编译时必须要知道函数的参数类型,模板的实参等,以使编译器生成唯•的内部标识,对于运行时多态,在程序运行时,根据程序当前的数据环境选择执行不同的代码,如虚拟函数。.有如下定义:classMA{intvalue;public:MA(intn=0):value(n){});MA*ta,tb;其中MA类的对象名标识符是ota是一个指向MA对象的指针,它不是对象名标识,tb是一个MA对象的标识。2007年9月考试真题(第26次).下列叙述中正确的是.A、数据库系统是一个独立的系统,不需要操作系统的支持B,数据库技术的根本目标是要

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论