2023年最新全国计算机等级考试二级c++题库7共17套.doc

上传人:教**** 文档编号:68531332 上传时间:2022-12-28 格式:DOC 页数:29 大小:91.04KB
返回 下载 相关 举报
2023年最新全国计算机等级考试二级c++题库7共17套.doc_第1页
第1页 / 共29页
2023年最新全国计算机等级考试二级c++题库7共17套.doc_第2页
第2页 / 共29页
点击查看更多>>
资源描述

《2023年最新全国计算机等级考试二级c++题库7共17套.doc》由会员分享,可在线阅读,更多相关《2023年最新全国计算机等级考试二级c++题库7共17套.doc(29页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、第七套1、 数据库管理系统是_。A、操作系统的一部分B、在操作系统支持下的系统软件C、一种编译系统D、一种操作系统 数据库管理系统是数据库的机构,它是一种系统软件,负责数据库中的数据组织、数据操纵、数据维护、控制及保护和数据服务等。故本题答案为B。2、 对于循环队列,下列叙述中对的的是_。A、队头指针是固定不变的B、队头指针一定大于队尾指针C、队头指针一定小于队尾指针D、队头指针可以大于队尾指针,也可以小于队尾指针 所谓循环队列,就是将队列存储空间的最后一个位置绕到第一个位置,形成逻辑上的环状空间,供队列循环使用。 在循环队列中,用队尾指针rear指向队列中的队尾元素,用排头指针front指向

2、排头元素的前一个位置。 循环队列重要有两种基本运算:入队运算与退队运算。每进行一次入队运算,队尾指针就进一。每进行一次退队运算,排头指针就进一。当rear或front的值等于队列的长度+1时,就将rear或front的值置为1。一般情况下,rear大于front,由于入队的元素肯定比出队的元素多。特殊的情况是rear到达数组的上限之后又从数组的低端开始,此时,rear是小于front的。故本题答案为D。3、 算法的空间复杂度是指_。A、算法在执行过程中所需要的计算机存储空间B、算法所解决的数据量C、算法程序中的语句或指令条数D、算法在执行过程中所需要的临时工作单元数 一个算法的空间复杂度,一般

3、是指执行这个算法所需要的内存空间。故本题答案为A。4、 下列数据结构中,可以按照先进后出原则存取数据的是_。A、循环队列B、栈C、队列D、二叉树 在栈中,允许插入与删除的一端称为栈顶,而不允许插入与删除的另一端称为栈底。栈顶元素总是最后被插入的元素,从而也是最先能被删除的元素;栈底元素总是最先被插入的元素,从而也是最后才干被删除的元素。即栈是按照先进后出或后进先出的原则组织数据的。故本题答案为B。5、 在E-R图中,用来表达实体联系的图形是_。A、椭圆形B、矩形C、菱形D、三角形 在E-R图中用矩形表达实体集,用椭圆形表达属性,用菱形表达联系。故本题答案为C。6、有三个关系R,S和T如下: 其

4、中关系T由关系R和S通过某种操作得到,该操作为_。A、选择B、投影C、交D、并 并:设关系R和关系S具有相同的目n(即两个关系都有n个属性),且相应的属性取自同一个域,则关系R与关系S的并由属于R或属于S的元组组成。本题中,关系T是关系R和关系S进行并运算得到的。故本题答案为D。7、 软件设计中划分模块的一个准则是_。A、低内聚低耦合B、高内聚低耦合C、低内聚高耦合D、高内聚高耦合 耦合性与内聚性是模块独立性的两个定性标准。在程序结构中,各模块的内聚性越强,则耦合性越弱。一般较优秀的软件设计,应尽量做到高内聚,低耦合,即减弱模块之间的耦合性和提高模块内的内聚性,有助于提高模块的独立性。故本题答

5、案为B。8、 下列数据结构中,属于非线性结构的是_。A、循环队列B、带链队列C、二叉树D、带链栈 假如一个非空的数据结构满足下列两个条件:(1)有且只有一个根结点;(2)每一个结点最多有一个前件,也最多有一个后件。则称该数据结构为线性结构。本题中循环队列、带链队列和带链栈都是线性结构,二叉树是非线性结构。故本题答案为C。9、 下列选项中不属于结构化程序设计原则的是_。A、可封装B、自顶向下C、模块化D、逐步求精 结构化程序设计方法的重要原则可以概括为自顶向下,逐步求精,模块化,限制使用goto语句。故本题答案为A。10、软件具体设计产生的图如下: 该图是_。A、N-S图B、PAD图C、程序流程

6、图D、E-R图 程序流程图是一种传统的、应用广泛的软件过程设计表达工具,通常也称为程序框图,箭头表达控制流,矩形表达加工环节,菱形表达逻辑条件。故本题答案为C。11、有如下程序:#include#includeusing namespace std;int main() int s=123,234; coutrightsetfill(*)setw(6); for(int i=0;i2;i+) coutsiendl; return 0;运营时的输出结果是_。A、123 234B、*123 234C、*123 *234D、*123 234* 本题重要考察了输出格式控制。 right设立在设定的宽度

7、内右对齐输出(默认对齐方式),用填充字符填充左边。setfill(*)设立填充字符为*。setw(6)指定输出宽度为6,在一个数据输出完后,宽度自动恢复为默认值0(表达按数据实际宽度输入输出)。因此第一行输出结果为*123,第2行输出结果为234。 故本题答案为B。12、有如下程序:#include using namespace std;class C1public: C1() cout1;class C2:public C1public: C2()cout2;int main() C2 cb2; C1 *cb1; return 0;运营时的输出结果是_。A、121B、21C、211D、12

8、 本题重要考察了派生类析构函数的执行顺序。 析构函数用来完毕对象被删除前的一些清理工作,在对象的生存期即将结束的时候由系统自动调用。删除派生类对象时,析构函数的执行顺序如下:(1)执行派生类的析构函数;(2)执行派生类成员对象所在类的析构函数;(3)执行基类析构函数。在main()函数中,第一条语句定义了派生类C2的对象cb2,第二条语句声明对象指针cb1,声明指针,只是得到了用于存储地址的指针变量,不会创建对象,故本程序只创建了一个对象cb2。当main()函数结束时,派生类对象cb2被删除前,系统先执行派生类C2的析构函数,输出2,然后调用基类C1的析构函数,输出1。故本程序运营时的输出结

9、果是21。故本题答案为B。13、在下列枚举符号中,用来表达相对于当前位置文献定位方式的是_。A、ios_base:curB、ios_base:begC、ios_base:outD、ios_base:end 本题重要考察了文献流的定位。 C+流的定位方式(也就是指针移动方式)有三种: ios_base:beg:相对于文献首。 ios_base:cur:相对于当前位置(负数表达当前位置之前)。 ios_base:end:相对于文献尾。故本题答案为A。14、Sample是一个类,执行下面语句后,调用Sample类的构造函数的次数是_。Sample a2, *p=new Sample;A、0B、1C、

10、2D、3 本题重要考察了构造函数。 构造函数在对象被创建的时候由系统自动调用。本题定义了一个具有2个元素的对象数组a和一个指向动态创建对象的指针p,因此共创建了3个对象。故Sample类的构造函数被调用3次。故本题答案为D。15、已知函数FA调用FB,若要把这两个函数定义在同一个文献中,则_。A、FA必须定义在FB之前B、FB必须定义在FA之前C、若FA定义在FB之后,则FA的原型必须出现在FB的定义之前D、若FB定义在FA之后,则FB的原型必须出现在FA的定义之前 本题重要考察了函数原型。 在C+中,函数在使用之前要预先声明原型。因此假如函数FB定义在函数FA之后,则必须在函数FA之前声明函

11、数FB的原型,才可以在函数FA中调用函数FB。故本题答案为D。16、有如下程序段:int i=1;while(1) i+; if(i=10) break; if(i%2=0) cout*;执行这个程序段输出字符*的个数是_。A、10B、3C、4D、5 本题重要考察了while循环和if语句。 在while循环中,变量i的值从1开始,按步长值1递增,当i的值等于10时退出while循环,当i的值为2的整数倍且i的值不等于10时,输出字符*,故执行这个程序段输出字符*的个数为4。故本题答案为C。17、有如下模板声明:template class A;下列声明中,与上述声明不等价的是_。A、temp

12、late class A;B、template class A;C、template class A;D、template class A; 本题重要考察了类模板的声明。 在C+中,类模板声明的语法形式为: template class 类名; 每个模板形参具有下面几种形式: (1)typename (2)class (3)类型修饰 在这三种形式中,前两种是等价的:在声明模板参数时,关键字typename与class可以互换。因此选项A、B、C和该题模板声明等价。故本题答案为D。18、有如下程序:#includeusing namespace std;class Apublic: A(int

13、i):r1(i) void print() cout Er1-; void print() const cout Cr1*r1-;private: int r1;int main() A a1(2); const A a2(4); a1.print();a2.print(); return 0;运营时的输出结果是_。A、运营时犯错B、E2-C16-C、C4-C16-D、E2-E4- 本题重要考察了常对象和常成员函数。 使用const关键字修饰的对象称为常对象,使用const关键字说明的成员函数称为常成员函数,const关键字可以用于对重载函数的区分。本题在A类中说明了两个同名函数print,其

14、中一个是常函数。在主函数main中说明了两个对象a1和a2,其中a2是常对象。假如将一个对象说明为常对象,则通过该常对象只能调用它的常成员函数,不能调用其他成员函数,因此通过对象a1调用的是没有用const修饰的函数print,输出E2-,而通过对象a2调用的是用const修饰的常函数print,输出C16-。故本题程序运营时的输出结果是E2-C16-。故题答案为B。19、下列关于虚基类的描述中,错误的是_。A、使用虚基类可以消除由多继承产生的二义性B、构造派生类对象时,虚基类的构造函数只被调用一次C、声明class B:virtual public A说明类B为虚基类D、建立派生类对象时,一

15、方面调用虚基类的构造函数 本题重要考察了虚基类。 当一个派生类从多个基类派生,而这些基类又有一个共同的基类,当对该基类中说明的成员进行访问时,也许出现二义性。虚基类就是为了解决这种二义性问题提出来的,因此选项A对的。 使用虚基类解决二义性问题的关键是在派生类中只产生一个虚基类子对象,因此,在建立派生类的一个对象时,为保证虚基类子对象只被初始化一次,这个虚基类构造函数必须只被调用一次,因此选项B对的。 虚基类的说明格式如下: class :virtual 选项C中声明class B:virtual public A说明类A为虚基类,因此选项C错误。 建立派生类对象时,根据派生类构造函数的执行顺序

16、,应一方面调用基类构造函数,因此选项D对的。 故本题答案为C。20、下列关于运算符重载的描述中,错误的是_。A、:运算符不能重载B、类型转换运算只能作为成员函数重载C、将运算符作为非成员函数重载时必须定义为友元D、重载运算符应完毕下标访问操作 本题重要考察了运算符重载。 C+语言规定,除了.、.*、-*、:、?:这五个运算符外,其他运算符都可以重载,因此选项A是对的;在C+中,运算符函数重载一般有两种形式:重载为类的成员函数和重载为类的非成员函数。非成员函数通常是友元。(可以把一个运算符作为一个非成员、非友元函数重载。但是,这样的运算符函数访问类的私有和保护成员时,必须使用类的公有接口中提供的

17、设立数据和读取数据的函数,调用这些函数时会减少性能。),因此选项C错误;=、()、-以及所有的类型转换运算符只能重载为成员函数,因此选项B对的;重载的应完毕下标访问操作,使得向指定下标处的元素赋值或取值成为也许,因此选项D对的。 故本题答案为C。21、计算斐波那契数列第n项的函数定义如下:int fib(int n) if(n=0) return 1; else if(n=1) return 2; else return fib(n-1)+fib(n-2);若执行函数调用表达式fib(2),函数fib被调用的次数是_。A、1B、2C、3D、4 本题重要考察了递归函数。 假如一个函数在其函数体内

18、直接或间接地调用了自己,该函数就称为递归函数。若执行函数调用表达式fib(2),则执行表达式fib(2-1)+fib(2-2),即执行表达式fib(1)+fib(0),故函数fib共被调用了3次:fib(2)、fib(1)和fib(0)。 故本题答案为C。22、下列关于模板形参的描述中,错误的是_。A、模板形参表必须在关键字template之后B、模板形参表必须用括弧( )括起来C、可以用class修饰模板形参D、可以用typename修饰模板形参 本题重要考察了模板。 在C+中,模板分为函数模板和类模板。声明一个函数模板的格式是: template 声明一个类模板的格式是: template

19、 所有模版的定义都以关键字template开始,模板形参表必须在关键字template之后,因此选项A对的;必须用一对尖括号括起来,因此选项B错误。 每个具有下面几种形式: (1)typename (2)class (3)类型修饰 在这三种形式中,前两种是等价的:在声明模板参数时,关键字typename与class可以互换,因此选项C、D对的。故本题答案B。23、已知数组arr的定义如下:int arr5=1,2,3,4,5;下列语句中输出结果不是2的是_。A、cout*arr+1endl;B、cout*(arr+1)endl;C、coutarr1endl;D、cout*arr A表达式可输出

20、字符AB、eof()函数可以检测是否到达文献尾C、对磁盘文献进行流操作时,必须包含头文献fstreamD、以ios_base:out模式打开的文献不存在时,将自动建立一个新文献 本题重要考察了C+流。 cout是C+流预定义的标准输出流对象。插入运算符是提取运算符,用于从一个输入流对象获取字节。故选项A的描述错误。 故本题答案是A。25、下列关于运算符函数的描述中,错误的是_。A、运算符函数的名称总是以operator为前缀B、运算符函数的参数可以是对象C、运算符函数只能定义为类的成员函数D、在表达式中使用重载的运算符相称于调用运算符重载函数 本题重要考察了运算符重载。 运算符函数的函数名是由

21、运算符前加关键字operator构成的,因此选项A对的;运算符的重载形式有两种,重载为类的成员函数和重载为类的友元函数,因此选项C错误;在表达式中使用重载的运算符相称于调用运算符重载函数,因此选项D对的;运算符函数的参数可以是对象,因此选项B对的。故本题答案为C。26、有如下程序:#includeusing namespace std;class AApublic: AA()cout 1;class BB:public AA int k;public: BB():k(0)cout2; BB(int n):k(n)cout 3;int main() BB b(4),c; return 0;运营时

22、的输出结果是_。A、1312B、132C、32D、1412 本题重要考察了类的继承与派生。 建立派生类对象时,构造函数的执行顺序如下:(1)执行基类的构造函数,调用顺序按照各个基类被继承时声明的顺序(自左向右);(2)执行成员对象的构造函数,调用顺序按照各个成员对象在类中声明的顺序(自上而下);(3)执行派生类的构造函数。在main()函数中,第一条语句定义了两个派生类BB的对象:b和c,并初始化对象b。创建对象b时构造函数的执行顺序:执行基类AA的构造函数,输出1,然后执行派生类BB的带参数的构造函数,输出3;创建对象c时构造函数的执行顺序为:执行基类AA的构造函数,输出1,然后执行派生类B

23、B的不带参数的构造函数,输出2。故程序运营时的输出结果是1312。 故本题答案为A。27、有如下程序:#includeusing namespace std;class Name char name20;public: Name() strcpy(name,); cout?; Name(char *fname) strcpy(name,fname); cout?; ;int main() Name names3=Name(张三),Name(李四); return 0;运营此程序输出符号?的个数是_。A、0B、1C、2D、3 本题重要考察了构造函数。 构造函数在对象被创建的时候由系统自动调用。本

24、题的构造函数有两种重载形式:有参数的和无参数的,无参数的构造函数也称为默认形式的构造函数。main()函数中,第一条语句定义了一个具有3个元素的Name类对象数组names,即创建了三个Name类对象,建立前两个对象时,给出初始值,因此调用有参数的构造函数,输出2个?,建立第三个对象时调用无参数的构造函数,输出1个?,因此运营此程序输出符号?的个数是3。故本题答案为D。28、下列字符串中可以用作C+标记符的是_。A、2023varB、gotoC、test-2023D、_123 本题重要考察了标记符。 标记符的组成要符合一定的规则: 标记符是一个以字母或下划线开头的,由字母、数字、下划线组成的字

25、符串; 标记符不能与任意一个关键字同名; 标记符中的字母区分大小写; 标记符不宜过长。 选项A的第一个字符是数字,选项B是关键字,选项C中的字符-不合法。只有选项D可以用作C+标记符。故本题答案为D。29、下列枚举类型的定义中,包含枚举值3的是_。A、enum testRED,YELLOW,BLUE,BLACK;B、enum testRED,YELLOW=4,BLUE,BLACK;C、enum testRED=-1,YELLOW,BLUE,BLACK;D、enum testRED,YELLOW=6,BLUE,BLACK; 本题重要考察了枚举常量。 枚举常量是枚举类型中定义的值,即枚举值。枚举类

26、型事实上是int类型的一个子集,其每一个枚举值代表一个整数;n个枚举值所有未赋常量值时,它们自左至右分别与整数0,1n-1相应;若第i个枚举值赋常量值为m,则其未赋常量值的后续枚举值分别与整数m+1,m+2相应,直到下一个赋了值的枚举值或结束。因此只有选项A包含枚举值3。故本题答案为A。30、有如下类定义:class XX int xdata;public: XX(int n=0):xdata(n) ;class YY:public XX int ydata;public: YY(int m=0,int n=0):XX(m),ydata(n) ;YY类的对象包含的数据成员的个数是_。A、1B、

27、2C、3D、4 本题重要考察了类的继承与派生。 派生类继承了基类的所有数据成员和除了构造、析构函数之外的所有成员函数。在一个派生类中,其成员由两部分构成:一部分是从基类继承得到的,另一部分是自己定义的新成员。因此派生类YY的数据成员有两个:一个是从基类XX继承得到的xdata,另一个是自己定义的新数据成员ydata。故本题答案为B。31、有如下程序:#includeusing namespace std;class Publication /出版物类 char name30;public: Publication(char *name= 未知名称) strcpy(this-name,name)

28、; const char * getName() constreturn name; virtual const char * getType()constreturn 未知类型;class Book:public Publication /书类public: Book(char *name):Publication(name) virtual const char * getType()constreturn 书;void showPublication(Publication &p) coutp.getType():p.getName()endl;int main() Book book(

29、精彩人生); showPublication(book); return 0;运营时的输出结果是_。A、未知类型:未知名称B、未知类型:精彩人生C、书:未知名称D、书:精彩人生 本题重要考察了虚函数与多态性。 在C+中,一个基类指针(或引用)可以用于指向它的派生类对象,并且通过这样的指针(或引用)调用虚函数时,被调用的是该指针(或引用)实际所指向的对象类的那个重定义版本。在实函数的情况下,通过基类指针(或引用)所调用的只能是基类的那个函数版本,无法调用到派生类中的重定义函数。在main()函数中,第一条语句定义了派生类Book的对象book,建立派生类对象时,构造函数的执行顺序:先执行基类的构

30、造函数,初始化基类数据成员数组name为字符串精彩人生,然后执行派生类的构造函数。第二条语句以派生类对象book为实参调用函数showPublication(),函数showPublication()的形参为基类引用p,即基类引用p指向派生类对象book。基类Publication的成员函数getType()被定义成虚函数,这个虚函数在派生类Book中被重定义。因此p.getType()调用的是派生类的那个重定义版本,函数返回值为书。成员函数getName()为实函数,p.getName()调用的是基类的那个版本,函数返回值为基类的数据成员,即精彩人生。故程序运营时的输出结果是书:精彩人生。

31、故本题答案为D。32、将运算符重载为类成员函数时,其参数表中没有参数,说明该运算符是_。A、不合法的运算符B、一元运算符C、无操作数的运算符D、二元运算符 本题重要考察了运算符重载。 运算符的重载形式有两种,重载为类的成员函数和重载为类的友元函数。运算符重载为成员函数时,由于此成员函数所属的对象可成为运算符的一个运算分量,所以形参个数一般为运算符的元数减1。因此将运算符重载为类的成员函数时,其参数表中没有参数,说明该运算符是一元运算符。故本题答案为B。33、有如下两个类定义:class AA;class BB AA v1,*v2; BB v3; int *v4;其中有一个成员变量的定义是错误的

32、,这个变量是_。A、v1B、v2C、v3D、v4 本题重要考察了类和对象。 C+规定,在提供一个完整的类声明之前,不能声明该类的对象。本题在完整声明类BB之前声明了类BB的对象v3,故成员变量v3的定义是错误的。故本题答案为C。34、有如下程序:#include using namespace std;class Toypublic: Toy(char* _n)strcpy(name,_n); count+; Toy()count-; char* GetName() return name; static int getCount() return count;private: char na

33、me10; static int count;int Toy:count=0; int main() Toy t1(Snoopy),t2(Mickey),t3(Barbie); coutt1.getCount()endl; return 0;运营时的输出结果是_。A、1B、2C、3D、运营时犯错 本题重要考察了静态数据成员。 一个类的静态数据成员被这个类的所有对象所共享,但它不属于类的任何一个对象。它的作用域是类范围。本题中,Toy类定义了一个静态数据成员count,并被初始化为0。main函数的第一条语句定义了3个Toy类对象t1、t2和t3,由于每创建一个Toy类对象,系统自动调用一次To

34、y类的构造函数,count的值就增1,故第一条语句执行结束后,静态数据成员count的值为3,第二条语句调用静态成员函数getCount(),在屏幕上输出count的值,最后执行return语句返回,整个程序执行结束。因此本题程序运营时的输出结果是3。故题答案为C。35、有如下类定义:class A char *a;public: A():a(0) A(char *aa) /把aa所指字符串拷贝到a所指向的存储空间 a=_; strcpy(a,aa); A() delete a; 横线处应填写的表达式是_。A、new charstrlen(aa)+1B、charstrlen(aa)+1C、ch

35、arstrlen(aa)D、new charsizeof(aa)-1 本题重要考察了动态存储分派。 动态存储分派功能在C+中是通过new和delete运算符来实现的。运算符new用于申请动态存储空间,它的操作数为某种数据类型且可以带有初值表达式或元素个数。new返回一个指向其操作数类型变量的指针。使用new对某种类型变量进行动态分派的语法格式为:=new; 其中,表达要分派的变量类型(如char、int、double);表达指向类型变量的指针(如char*、int*、double*等)。 类A的带参数构造函数的功能是把aa所指字符串拷贝到指针a所指向的存储空间,根据待填空的下一条语句可以判断横

36、线处表达式的功能应为申请分派用于存放拷贝aa所指字符串的存储空间,函数strlen的功能是获得字符串有效字符的个数,字符串应以字符0结束,而字符串结束符0也占用一个字符空间,故横线处的表达式为new charstrlen(aa)+1。故本题答案为A。36、软件开发过程重要分为需求分析、设计、编码与测试四个阶段,其中_阶段产生软件需求规格说明书。标准答案为:需求分析软件需求规格说明书是需求分析阶段产生的最后成果,是软件开发中的重要文档之一。37、程序流程图中的菱形框表达的是_。标准答案为:逻辑条件 或 逻辑判断程序流程图是一种传统的、应用广泛的软件过程设计表达工具,通常也称为程序框图,箭头表达控

37、制流,矩形表达加工环节,菱形表达逻辑条件。38、人员基本信息一般涉及:身份证号,姓名,性别,年龄等。其中可以作为主关键字的是_。标准答案为:身份证号主关键字能惟一标记每条记录。主关键字可以是一个字段,也可以是一组字段。本题中能惟一标记一条记录的是身份证号。39、某二叉树有5个度为2的结点以及3个度为1的结点,则该二叉树中共有_个结点。标准答案为:14 或 或 十四二叉树的性质3:在任意一棵二叉树中,度为0的结点(即叶子结点)总是比度为2的结点多一个。本题中度为0的结点数为5+1=6,该二叉树中的总结点数为5+3+6=14。40、在数据库技术中,实体集之间的联系可以是一对一或一对多或多对多的,那

38、么学生和可选课程的联系为_。标准答案为:多对多 或 m:n 或 n:m 或 m:n 或 n:m41、有如下类定义: class Samplepublic: Sample(); Sample();private: static int data;将静态数据成员data初始化为0的语句是_。标准答案为:int Sample:data=0; 本题重要考察了静态数据成员。 类Sample的数据成员data为静态数据成员,静态数据成员为类的所有对象所共享,但它不属于类的任何一个对象。静态数据成员初始化的一般格式如下: :=因此将静态数据成员data初始化为0的语句是int Sample:data=0;。

39、42、如下程序定义了单词类Word,类中重载了运算符,用于比较单词的大小,返回相应的逻辑值。程序的输出结果为:After Sorting: Happy Welcome,请将程序补充完整。#include #include using namespace std;class Wordpublic: Word(string s):str(s) string getstr()return str; _ const return (strw.str); friend ostream& operator(ostream& output,const Word &w) outputw.str; return

40、 output;private: string str;int main() Word w1(Happy),w2(Welcome); coutAfter sorting: ; if(w1w2) coutw1 w2; else coutw2 w1; return 0;标准答案为:bool operator(Word w) 或 bool operator(Word& w) 本题重要考察了运算符重载。C+把重载的运算符视为特殊的函数,称为运算符函数,函数名就是在运算符前加上保存字operator,因此运算符的函数名为operator 。由函数体语句return (strw.str);可知:运算符函数的返回值类型为bool,str为成员函数所属对象的数据成员,对象w为运算符函数的参数,故运算符被重载为成员函数。运算符重载为成员函数时,由于此成员函数所属的对象可成为运算符的一个运算分量,所以形参个数一般为运算符

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 初中资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁