1、1面向对象程序设计期末复习题2一、单选题1. 6. 能作为 C+程序的基本单位是( c )。A. 字符 B. 语句 C. 函数 D. 源程序文件2. 10. 存储以下数据,占用存储字节最多的是( d )。A. 0 B. 0 C. “0” D. 0.03. 14. 设”int a=15,b=26;”,则”couta D. x.a30. 109. 假定 AA 为一个类,a()为该类公有的函数成员,x 为该类的一个对象,则访问 x 对象中函数成员 a()的格式为( b )。A. x.a B. x.a() C. x-a D. x-a()31. 110. 假定 AA 为一个类,a 为该类公有的数据成员,
2、px 为指向该类对象的一个指针,则访问 px 所指对象中数据成员 a 的格式为( c )。A. px(a) B. pxa C. px-a D. px.a32. 111. 假定 AA 为一个类,a 为该类私有的数据成员,GetValue()为该类公有函数成员,它返回 a 的值,x 为该类的一个对象,则访问 x 对象中数据成员 a 的格式为( d )。A. x.a B. x.a() C. x-GetValue() D. x.GetValue()33. 112. 假定 AA 为一个类,int a()为该类的一个成员函数,若该成员函数在类定义体外定义,则函数头为( a )。A. int AA:a()
3、B. int AA:a() C. AA:a() D. AA:int a()34. 113. 假定 AA 为一个类,a 为该类公有的数据成员,若要在该类的一个成员函数中访问它,则书写格式为( a )。A. a B. AA:a C. a() D. AA:a()35. 114. 若需要把一个类外定义的成员函数指明为内联函数,则必须把关键字( b )放在函数原型或函数头的前面。A. in B. inline C. inLine D. InLiner36. 115. 在多文件结构的程序中,通常把类的定义单独存放于( d )中。A. 主文件 B. 实现文件 C. 库文件 D. 头文件37. 116. 在多
4、文件结构的程序中,通常把类中所有非内联函数的定义单独存放于( b )中。A. 主文件 B. 实现文件 C. 库文件 D. 头文件38. 117. 在多文件结构的程序中,通常把含有 main()函数的文件称为( a )。A. 主文件 B. 实现文件 C. 程序文件 D. 头文件39. 118. 一个 C+程序文件的扩展名为( c )。A. .h B. .c C. .cpp D. .cp40. 119. 在 C+程序中使用的 cin 标识符是系统类库中定义的( a )类中的一个对象。A. istream B. ostream C. iostream D. fstream41. 120. 在 C+程
5、序中使用的 cout 标识符是系统类库中定义的( b )类中的一个对象。A. istream B. ostream C. iostream D. fstream542. 121. 假定 AA 是一个类,abc 是该类的一个成员函数,则参数表中隐含的第一个参数的类型为( d )。A. int B. char C. AA D. AA*43. 122. 假定 AA 是一个类,abc 是该类的一个成员函数,则参数表中隐含的第一个参数为( c )。A. abc B. *this C. this D. this”是该类中一个成员函数的原型,若该函数存在对*this 赋值的语句,当用 x.abc()调用该成
6、员函数后,x 的值( a )。A. 已经被改变 B. 可能被改变C. 不变 D.不受函数调用的影响45. 124. 假定 AA 是一个类,“AA* abc()const;”是该类中一个成员函数的原型,若该函数返回 this 值,当用 x.abc()调用该成员函数后,x 的值( c )。A. 已经被改变 B. 可能被改变C. 不变 D. 受到函数调用的影响46. 125. 类中定义的成员默认为( b )访问属性。A. public B. private C. protected D. friend47. 126. 结构中定义的成员默认为( a )访问属性。A. public B. private
7、 C. protected D. friend48. 127. 当类中一个字符指针成员指向具有 n 个字节的存储空间时,它所能存储字符串的最大长度为( c )。A. n B. n+1 C. n-1 D. n-249. 135. 对于一个类的构造函数,其函数名与类名( a )。A. 完全相同 B. 基本相同 C. 不相同 D. 无关系50. 136. 对于一个类的析构函数,其函数名与类名( c )。A. 完全相同 B. 完全不同 C. 只相差一个字符 D. 无关系51. 137. 类的构造函数是在定义该类的一个( c )时被自动调用执行的。A. 成员函数 B. 数据成员 C. 对象 D. 友元函
8、数52. 138. 类的析构函数是一个对象被( b )时自动调用的。A. 建立 B. 撤消 C. 赋值 D. 引用53. 139. 一个类的构造函数通常被定义为该类的( a )成员。A. 公用 B. 保护 C. 私有 D. 友元54. 140. 一个类的析构函数通常被定义为该类的( c )成员。A. 私有 B. 保护 C. 公用 D. 友元55. 141. 假定 AB 为一个类,则执行 “AB x;”语句时将自动调用该类的( b )。A. 带参构造函数 B. 无参构造函数 C. 拷贝构造函数 D. 赋值重载函数56. 142. 假定 AB 为一个类,则执行 “AB x(a,5);”语句时将自动
9、调用该类的( a )。A. 带参构造函数 B. 无参构造函数 C. 拷贝构造函数 D. 赋值重载函数57. 143. 假定 AB 为一个类,则执行 “AB *s=new AB(a,5);”语句时得到的一个动态对象为_d_。A. s B. s-a C. s.a D. *s58. 144. 假定 AB 为一个类,则执行 “AB r1=r2;”语句时将自动调用该类的( d )。6A. 无参构造函数 B. 带参构造函数 C. 赋值重载函数 D. 拷贝构造函数59. 145. 若需要使类中的一个指针成员指向一块动态存储空间,则通常在( b )函数中完成。A. 析构 B. 构造 C. 任一成员 D. 友元
10、60. 146. 当类中的一个整型指针成员指向一块具有 n*sizeof(int)大小的存储空间时,它最多能够存储( a )个整数。A. n B. n+1 C. n-1 D. 161. 147. 假定一个类的构造函数为 “A(int aa, int bb) a=aa; b=aa*bb;”,则执行 “A x(4,5);”语句后,x.a 和 x.b 的值分别为( c )。A. 4 和 5 B. 5 和 4 C. 4 和 20 D. 20 和 562. 148. 假定一个类的构造函数为 “A(int aa=1, int bb=0) a=aa; b=bb;”,则执行 “A x(4);”语句后,x.a
11、和 x.b 的值分别为( d )。A. 1 和 0 B. 1 和 4 C. 4 和 1 D. 4 和 063. 149. 假定 AB 为一个类,则( b )为该类的拷贝构造函数的原型说明。A. AB(AB x); B. AB(AB C. void AB(AB D. AB(int x);64. 150. 假定一个类的构造函数为 “B(int ax, int bx): a(ax), b(bx) ”,执行 “B x(1,2),y(3,4);x=y;”语句序列后 x.a 的值为( c )。A. 1 B. 2 C. 3 D. 465. 151. 假定一个类 AB 只含有一个整型数据成员 a,当用户不定义
12、任何构造函数时,系统为该类定义的无参构造函数为( d )。A. AB() a=0; B. AB(int aa=0): a(aa) C. AB(int aa): a(aa) D. AB() 66. 152. 假定一个类 AB 只含有一个整型数据成员 a,用户为该类定义的带参构造函数可以为( c )。A. AB() B. AB(): a(0)C. AB(int aa=0) a=aa; D. AB(int aa) 67. 153. 对于任一个类,用户所能定义的构造函数的个数至多为( d )。A. 0 B. 1 C. 2 D. 任意个68. 154. 对于任一个类,用户所能定义的析构函数的个数至多为(
13、 b )。A. 0 B. 1 C. 2 D. 任意个69. 155. 假定 AB 为一个类,则执行 “AB *px=new ABn;”语句时将( a )。A. 动态分配一个数组 B. 动态分配一个对象C. 静态分配一个数组 D. 静态分配一个对象70. 156. 设 px 是指向一个类对象的指针变量,则执行 “delete px;”语句时,将自动调用该类的( c )。A. 无参构造函数 B. 带参构造函数 C. 析构函数 D. 拷贝构造函数71. 157. 当一个类对象离开它的作用域时,系统自动调用该类的( d )。A. 无参构造函数 B. 带参构造函数 C. 拷贝构造函数 D. 析构函数72
14、. 158. 假定一个类对象数组为 An,当离开它定义的作用域时,系统自动调用该类析构函数的次数为( c )。A. 0 B. 1 C. n D. n-173. 159. 假定 AB 为一个类,则执行 “AB a10;”语句时调用该类无参构造函数的次数为( d )。A. 0 B. 1 C. 9 D. 10774. 160. 假定 AB 为一个类,则执行 “AB *px=new ABn;”语句时调用该类无参构造函数的次数为( a )。A. n B. n-1 C. 1 D. 075. 161. 假定 AB 为一个类,则执行 “AB a, b(3), *p;”语句时共调用该类构造函数的次数为( a )
15、。A. 2 B. 3 C. 4 D. 576. 162. 假定 AB 为一个类,则执行 “AB a(2), b3, *p4;”语句时共调用该类构造函数的次数为( b )。A. 3 B. 4 C. 5 D. 977. 163. 假定 AB 为一个类,则执行“AB a, b(2), c3, *p=”语句时共调用该类无参构造函数的次数为( d )。A. 5 B. 6 C. 3 D. 478. 164. 假定 AB 为一个类,则执行“AB *p=new AB(1,2);”语句时共调用该类构造函数的次数为( b )。A. 0 B. 1 C. 2 D. 379. 165. 假定 AB 为一个类,px 为指
16、向该类的一个含有 n 个对象的动态数组的指针,则执行“delete px;”语句时共调用该类析构函数的次数为( c )。A. 0 B. 1 C. n D. n+180. 166. 对类对象成员的初始化是通过构造函数中给出的( b )实现的。A. 函数体 B. 初始化表 C. 参数表 D. 初始化表或函数体81. 167. 对类中常量成员的初始化是通过构造函数中给出的( c )实现的。A. 函数体 B. 参数表 C. 初始化表 D. 初始化表或函数体82. 169. 类的构造函数可以带有( c )个参数。A. 0 B. 1 C. 2 D. 任意83. 170. 类的析构函数可以带有( a )个参
17、数。A. 0 B. 1 C. 2 D. 任意84. 171. 一个类的静态数据成员所表示属性 ( c )。A. 是类的或对象的属性 B. 只是对象的属性C. 只是类的属性 D. 类和友元的属性 85. 172. 类的静态成员的访问控制( d )。A. 只允许被定义为 privateB. 只允许被定义为 private 或 protected C. 只允许被定义为 public D. 可允许被定义为 private、protected 或 public86. 173. 静态成员函数对类的数据成员访问( b )。A. 是不允许的 B. 只允许是静态数据成员 C. 只允许是非静态数据成员 D. 可允
18、许是静态数据成员或非静态数据成员87. 174. 被非静态成员函数访问的类的数据成员( a )。A. 可以是非静态数据成员或静态数据成员 B. 不可能是类的静态数据成员C. 只能是类的非静态数据成员 D. 只能是类的静态数据成员88. 175. 静态数据成员的初始化是在( d )中进行的。A. 构造函数 B. 任何成员函数C. 所属类 D. 全局区89. 178. 一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明( a )。8A. 需加上类域的限定 B. 不需加上类域的限定C. 类域的限定可加可不加 D. 不需要任何限定90. 179. 一个类的友元不是该类的成员,与该类的关系密切
19、,所以它( d )。A. 有 this 指针,有默认操作的对象 B. 没有 this 指针,可以有默认操作的对象C. 有 this 指针,不能执行默认操作D. 没有 this 指针,也就没有默认操作的对象91. 180. 在重载一个运算符时,其参数表中没有任何参数,这表明该运算符是( b )。A. 作为友元函数重载的 1 元运算符 B. 作为成员函数重载的 1 元运算符C. 作为友元函数重载的 2 元运算符 D. 作为成员函数重载的 2 元运算符92. 181. 在成员函数中进行双目运算符重载时,其参数表中应带有( b )个参数。A. 0 B. 1 C. 2 D. 393. 182. 双目运算
20、符重载为普通函数时,其参数表中应带有( c )个参数。A. 0 B. 1 C. 2 D. 394. 185. 如果表达式 a+中的“+”是作为普通函数重载的运算符,若采用运算符函数调用格式,则可表示为( c )。A. a.operator+() B. operator+(a)C. operator+(a,1) D. operator+(1,a)95. 186. 如果表达式+a 中的“+”是作为成员函数重载的运算符,若采用运算符函数调用格式,则可表示为( d )。A. a.operator+(1) B. operator+(a)C. operator+(a,1) D. a.operator+()
21、96. 187. 关于运算符重载,下列说法正确的是( c )。A. 重载时,运算符的优先级可以改变。B. 重载时,运算符的结合性可以改变。C. 重载时,运算符的功能可以改变。D. 重载时,运算符的操作数个数可以改变。97. 189. 一个程序中数组 a 和变量 k 定义为“int a510,k;”,且程序中包含有语句“a(2,5)=+k*3;”,则此语句中肯定属于重载操作符的是( a )。A. ( ) B. = C. + D. *98. 190. 假定 K 是一个类名,并有定义“K k; int j;”,已知 K 中重载了操作符 ( ),且语句“j=k(3);”和“k(5)=99;”都能顺利执
22、行,说明该操作符函数的原形只可能是( c )。A. K operator ( ) (int); B. int operator ( )(intC. int D. K 99. 195. 关于插入运算符 T cubin(T n)return n*n*n ; _。9. 97. 如果一个函数中有多个默认参数,则默认参数必须全部处在形参表的_右面_部分。10. 132. 若要把整型变量 y 定义为 x 的引用,则所使用的定义语句为_ int y=x;_。11. 133. 若 y 是 x 的引用,则对 y 的操作就是对_x_的操作。12. 134. 若 y 是 x 的引用,则 y 和 x 的值_相同_,即
23、为变量_x_的地址。13. 135. 执行 int p=new int 操作得到的一个动态分配的整型对象为_*p _。14. 137. 执行 char *p=new char(a)操作后,p 所指向的数据对象的值为_a_。15. 138. 执行 new charmn操作时的返回值的类型为_char(*)n_。16. 139. 执行_delete p_操作将释放由 p 所指向的动态分配的数据空间。17. 149. 已知变量 a 定义为“int a=5;”,要使 ra 成为 a 的引用,则 ra 应定义为_ int ra=a;_。18. 155. 对象将其大部分实现细节隐藏起来,这种机制称为_封装
24、_。19. 156. 基类和派生类的关系称为_继承_。20. 160. 如果一个派生类的基类不止一个,则这种继承称为_多继承_。21. 162. C+支持两种多态性:_编译_时的多态性和_运行_时的多态性。22. 163. 在 C+中,编译时的多态性是通过_重载_实现的,而运行时的多态性则是通过_虚函数_实现的。23. 172. 若在类的定义体中给出了一个成员函数的完整定义,则该函数属于_内联_函数。24. 173. 若在类的定义体中只给出了一个成员函数的原型,则在类外给出完整定义时,其函数名前必须加上_类名_和两个冒号分隔符。25. 175. 若要把类外定义的成员函数规定为内联函数,则必须把
25、_inline_关键字放到函数原型或函数头的前面。 26. 176. 把一个类的定义体和所有成员函数的定义体所构成的程序范围叫做该类的_作用域_。27. 177. 假定 AA 是一个类,“AA* abc();”是该类中一个成员函数的原型,则在类外定义时的函数头为_ AA* AA:abc()_。28. 178.成员函数的参数表在类作用域中,成员函数的返回值类型_不在_类作用域中。29. 179. 为了避免在调用成员函数时修改对象中的任何数据成员,则应在定义该成员11函数时,在函数头的后面加上_const_关键字。30. 180. 若只需要通过一个成员函数读取数据成员的值,而不需要修改它,则应在函
26、数头的后面加上_const_关键字。31. 183. 内联函数的定义模块与_类定义_模块必须放在同一个文件中。32. 184假定 AA 是一个类,“AA* abc()const;”是该类中一个成员函数的原型,在该函数体中(能够/不能够)_不能够_向*this 或其成员赋值。33. 201一个类的_构造_函数实现对该类对象的初始化功能。34. 202一个类的_析构_函数通常用于实现释放该类对象中指针成员所指向的动态存储空间的任务。35. 203当用户为一个类定义有_构造函数_时,则系统不会为该类再自动生成一个默认构造函数。36. 204假定用户没有给一个名为 AB 的类定义构造函数,则系统为其定
27、义的构造函数为_ AB() _。37. 205假定用户没有给一个名为 AB 的类定义析构函数,则系统为其定义的析构函数为_AB() _。38. 206定义类动态对象数组时,其元素只能靠自动调用该类的_无参构造函数_来进行初始化。39. 207在一个类中定义拷贝构造函数的目的,是为了当利用该类的一个对象初始化另一个对象时,能够避免这两个对象的同一指针同时指向同一块_动态存储空间_。40. 208为了释放类对象中指针成员所指向的动态存储空间,则需要为该类定义_析构函数_。41. 209. 假定 AB 为一个类,则执行“AB a10;”语句时,系统自动调用该类构造函数的次数为_10_。42. 210
28、假定一个类对象数组为 AN,当离开它的作用域时,系统自动调用该类析构函数的次数为_N_。43. 211对类中对象成员的初始化是通过在构造函数中给出的_初始化表_来实现的。44. 213对类中引用成员的初始化只能通过在构造函数中给出的_初始化表_来实现。45. 214对类中一般数据成员的初始化既可以通过在构造函数中给出的初始化表来实现,也可以通过构造函数中的_函数体_来实现。46. 215.假定要把 aa 定义为 AB 类中的一个常量整数型数据成员,则定义语句为_ const int aa;_。47. 216. 假定要把 aa 定义为 AB 类中的一个引用整数型数据成员,则定义语句为_ int
29、aa;_。48. 217. 假定 AB 类中只包含一个整型数据成员 a,并且它是一个常量成员,若利用参数 aa 对其进行初始化,则该类的构造函数的定义为_ AB(int aa):a(aa);_。49. 218.假定 AB 类中只包含一个整型数据成员 a,并且它是一个引用成员,若利用引用参数 aa 对其进行初始化,则该类的构造函数的定义为_ AB(int aa):a(aa);_。50. 219假定指针 p 指向一个动态分配的类对象,则当执行“delete p;”语句时,在释放 p 所指向的动态存储空间之前将自动调用该类的_析构函数_。51. 220假定用户为类 AB 定义了一个构造函数“AB(i
30、nt aa) a=aa;”,则系统(会/不会)_不会_为该类自动定义一个无参构造函数“AB() “。1252. 221. 假定用户为类 AB 定义了一个构造函数“AB(int aa, char *bb=NULL):a(aa),b(bb)”,则该类中至少包含有_2_个数据成员。53. 222假定用户为类 AB 定义了一个构造函数“AB(int aa) a=aa;”,该构造函数实现对数据成员_a_的初始化。54. 223假定用户为类 AB 定义了一个构造函数“AB(int aa=0):a(aa)”,则定义该类的对象时,可以有_2_种不同的定义格式。55. 224假定用户为类 AB 定义了一个构造函
31、数“AB(int aa):a(aa)”,则定义该类的对象时,有_1_种定义格式。56. 225假定用户只为类 AB 定义了一个构造函数“AB(int aa, int bb=0)a=aa; b=bb;”,则定义该类的对象时,其实参表中至多带有_2_个实参。57. 227假定用户为类 AB 定义了一个构造函数“AB(int aa=0, int bb=0)a=aa; b=bb;”,则定义该类的对象时,可以有_3_种不同的定义格式。58. 228假定用户只为类 AB 定义了一个构造函数“AB():a(0),b(0)”,则定义该类对象 x 的定义语句“AB x();”是_错误_(正确/错误)的。59.
32、231假定 AB 为一个类,则类定义体中的“AB(AB x);”语句为该类_拷贝构造函数_的原型语句。60. 232假定 AB 为一个类,则该类的拷贝构造函数的函数头为_ AB(AB)_。61. 233假定 AB 为一个类,该类中含有一个指向动态数组空间的指针成员 pa,则在该类的析构函数中应该包含有一条_ delete pa;_语句。62. 234. 静态成员函数_只能_访问类的静态数据成员, 不能访问类的非静态数据成员。63. 235. 静态数据成员必须在所有函数的定义体外进行_初始化_。64. 236. 一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明必须在函数名前加上_类域
33、_的限定。65. 237. 重载运算符时,该运算符的_优先级_、结合性以及操作符的个数不允许改变。66. 238. 一个单目运算符作为类的成员函数重载时有_0_个参数;如果作为独立函数重载,则有_1_个参数。67. 239. 一个双单目运算符作为类的成员函数重载时有_1_个参数;如果作为独立函数重载,则有_2_个参数。68. 241. 作为类的成员函数重载一个运算符时,参数表中只有一个参数,说明该运算符有_2_个操作数。69. 242. 在重载一个单目运算符时,参数表中没有参数,说明该运算符函数只能是类的_成员函数_。70. 243. 重载插入运算符时,其运算符函数的返回值类型应当是_ ist
34、ream _。72. 249. 派生类的成员函数可以直接访问基类的_共有和保护_成员,不能直接访问基类的 _私有_成员。73. 250. 当保护继承时,基类的_公有和保护_成员在派生类中成为保护成员,派生类对象不能直接访问基类的_任何_成员。74. 251. 在定义一个派生类时,使用_ private _关键字或者不显式地使用它则表示为_私有_继承。75. 252. 若多个基类及其派生类中都定义了同名函数成员,要访问相应函数时,就需要在函数名前加上_类名_和类区分符。 76. 253. 若要保证一个公共的基类在派生类中只产生一个基类子对象,则必须都以_13虚基类_的方式直接继承它。77. 25
35、4. 引进虚基类的根本目的是为了消除_二义性_。78. 255. 在每个成员函数中,隐含的第一个参数的参数名为_this_。 三、程序填充1. 21. 已知一维数组类 ARRAY 的定义如下,ARRAY 与普通一维数组区别是:其重载的运算符 要对下标是否越界进行检查。class ARRAY int *v; /指向存放数组数据的空间int s; /数组大小 public: ARRAY(int a, int n); ARRAY()delete v;int size() return s; int ;_(1)_ operator(int n) / 的运算符成员函数定义if(nclass AA int
36、 a10;int n;public:void SetA(int aa, int nn); /用数组 aa 初始化数据成员 a,/用 nn 初始化数据成员 nint MaxA(); /从数组 a 中前 n 个元素中查找最大值void SortA(); /采用选择排序的方法对数组 a 中前 n 个元素/进行从小到大排序void InsertA();/采用插入排序的方法对数组 a 中前 n 个元素进行从小到大排序void PrintA(); /依次输出数组 a 中的前 n 个元素;该类中 MaxA()函数的实现如下,请在标号位置补充适当的内容。int _(1)_ int x=a0;for(int i
37、=1; ix) _(2)_;_(3)_;15(1) (2) (3)5. 25. 已知一个类的定义如下:#includeclass AA int a10;int n;public:void SetA(int aa, int nn); /用数组 aa 初始化数据成员 a,/用 nn 初始化数据成员 nint MaxA(); /从数组 a 中前 n 个元素中查找最大值void SortA(); /采用选择排序的方法对数组 a 中前 n 个元素/进行从小到大排序void InsertA();/采用插入排序的方法对数组 a 中前 n 个元素进行从小到大排序void PrintA(); /依次输出数组 a
38、 中的前 n 个元素;void AA:SortA()int i,j;for(i=0; _(1)_; i+) int x=ai, k=i;for(j=i+1; jclass AA int a10;int n;public:void SetA(int aa, int nn); /用数组 aa 初始化数据成员 a,/用 nn 初始化数据成员 nint MaxA(); /从数组 a 中前 n 个元素中查找最大值void SortA(); /采用选择排序的方法对数组 a 中前 n 个元素/进行从小到大排序void InsertA();/采用插入排序的方法对数组 a 中前 n 个元素进行从小到大排序voi
39、d PrintA(); /依次输出数组 a 中的前 n 个元素;16void _(1)_ int i,j;for(i=1; i=0; j-)if(xclass AA int a10;int n;public:void SetA(int aa, int nn); /用数组 aa 初始化数据成员 a,/用 nn 初始化数据成员 nint MaxA(); /从数组 a 中前 n 个元素中查找最大值void SortA(); /采用选择排序的方法对数组 a 中前 n 个元素/进行从小到大排序void InsertA();/采用插入排序的方法对数组 a 中前 n 个元素进行从小到大排序void Prin
40、tA(); /依次输出数组 a 中的前 n 个元素/最后输出一个换行;使用该类的主函数如下:void main()int a10=23,78,46,55,62,76,90,25,38,42;AA x; _(1)_;int m=_(2)_;_(3)_;coutclass AA int a10;int n;public:void SetA(int aa, int nn); /用数组 aa 初始化数据成员 a,/用 nn 初始化数据成员 nint MaxA(); /从数组 a 中前 n 个元素中查找最大值void SortA(); /采用选择排序的方法对数组 a 中前 n 个元素/进行从小到大排序v
41、oid PrintA(); /依次输出数组 a 中的前 n 个元素,/最后输出一个换行;使用该类的主函数如下:void main()int a10=23,78,46,55,62,76,90,25,38,42;_(1)_; x.SetA(a,8);int _(2)_;_(3)_;x.PrintA();cout#includeclass A int *a; int n; int MaxLen;public:A(): a(0), n(0), MaxLen(0) A(int *aa, int nn, int MM) n=nn;MaxLen=MM;if(nMaxLen) exit(1);18_(1)_;
42、 /由 a 指向长度为 MaxLen 的动态数组for(int i=0; i#includeclass A int *a; int n; int MaxLen;public:A(): a(0), n(0), MaxLen(0) A(int *aa, int nn, int MM) n=nn;MaxLen=MM;if(nMaxLen) exit(1);a=new intMaxLen;_(1)_; /以 i 为循环变量把 aa 数组中每个元素值/传送给 a 数组的对应元素中 A();int GetValue(int i) return ai; /函数体返回 ai的值;_(2)_ /析构函数的类外定
43、义void main()int b10=1,2,3,4,5,6,7,8,9,10;A r(b,10,10);int i,s=0;_(3)_ ; /以 i 为循环变量,把 r 对象的 a 数据成员中的/每个元素值依次累加到 s 中19cout#include class CD char* a;int b;public:void Init(char* aa, int bb)a=new charstrlen(aa)+1;strcpy(a,aa);b=bb;23char* Geta() return a;int Getb() return b;void Output() coutclass CE pr
44、ivate:int a,b;int getmax() return (ab? a:b);public:int c;void SetValue(int x1,int x2, int x3) a=x1; b=x2; c=x3;int GetMax();int CE:GetMax() int d=getmax();return (dc? d:c);void main()int x=5,y=12,z=8;CE ex, *ep=ex.SetValue(x,y,z);coutSetValue(x+y,y-z,20);coutGetMax()class Franction /定义分数类int nume; /
45、定义分子int deno; /定义分母public:/把*this 化简为最简分数,具体定义在另外文件中实现void FranSimp(); /返回两个分数*this 和 x 之和,具体定义在另外文件中实现Franction FranAdd(const Franction/置分数的分子和分母分别 0 和 1void InitFranction() nume=0; deno=1;/置分数的分子和分母分别 n 和 dvoid InitFranction(int n, int d) nume=n; deno=d;/输出一个分数void FranOutput() cout#includeclass A
46、 char *a;public:A(char *s) a=new charstrlen(s)+1;strcpy(a,s);coutclass A int *a;public:A(int x=0):a(new int(x)A() delete a;int getA() return *a;void setA(int x) *a=x;void main() A x1,x2(3);A *p=p-setA(x2.getA()+5);x1.setA(15+x1.getA();coutclass A int a;public:A(int aa=0): a(aa) coutclass A int a,b;public:A() a=b=0;A(int aa, int bb) a=aa; b=bb;int Sum() return a+b;int* Mult() int