总《面向对象程序设计c++》综合复习题集及答案详解
更新时间:2024-02-27 20:28:01 阅读量: 综合文库 文档下载
- Java面向对象程序设计推荐度:
- 相关推荐
一、单选题
1. C++源程序文件的缺省扩展名为( A )。
A. cpp B. exe C. obj D. lik
2. 由C++源程序文件编译而成的目标文件的缺省扩展名为( C )。 A. cpp B. exe C. obj D. lik
3. 由C++目标文件连接而成的可执行文件的缺省扩展名为( B )。 A. cpp B. exe C. obj D. lik 4. 编写C++程序一般需经过的几个步骤依次是( )。 A. 编译、编辑、连接、调试 B. 编辑、编译、连接、调试 C. 编译、调试、编辑、连接 D. 编辑、调试、编辑、连接
5. 以下标识符中不全是保留字的是( )。 A. case for int B. default then while C. bool class long D. goto return char
6. 能作为C++程序的基本单位是( )。
A. 字符 B. 语句 C. 函数 D. 源程序文件 7. 程序中主函数的名字为( )。
A. main B. MAIN C. Main D. 任意标识符 8. C++程序的基本模块为( )。
A. 表达式 B. 标识符 C. 语句 D. 函数 9. 可用作C++语言用户标识符的一组标识符是( )。
A. void define +WORD B. a3_b3 _123 YN C. for -abc Case D. 2a DO sizeof
10. 存储以下数据,占用存储字节最多的是( )。 A. 0 B. ‘0’ C. “0” D. 0.0 11. 程序运行中需要从键盘上输入多于一个数据时,各数据之间应使用( )符号作为分隔符。
A. 空格或逗号 B. 逗号或回车 C. 逗号或分号 D. 空格或回车 12. 设”int a=12;”,则执行完语句”a+=a*a;”后,a的值是( )。 A. 12 B. 144 C. 156 D. 288
13. 假设在程序中 a、b、c 均被定义成整型,所赋的值都大于1,则下列能
正确表示代数式1/abc的表达式是( )。A. 1.0/a*b*c B. 1/(a*b*c) C. 1/a/b/(float)c D. 1.0/a/b/c
14. 设”int a=15,b=26;”,则”cout<<(a,b);”的输出结果是( )。
A. 15 B. 26,15 C. 15,26 D. 26
15. 设x是一个bool型的逻辑量,y的值为10,则表达式 x && y的值为( )。 A. 1 B. 0 C. 与x值相同 D. 与x值相反
16. x>0 && x<=10的相反表达式为( )。
A. x<=0 || x>10 B. x<=0 && x>10 C. x<=0 || x<=10 D. x>0 && x>10
17. x>0 || y==5的相反表达式为( )。
A. x<=0 || y!=5 B. x<=0 && y!=5 C. x>0 || y!=5 D. x>0 && y==5
18.设x和y均为bool量,则x && y为真的条件是( )。 A. 它们均为真 B. 其中一个为真 C. 它们均为假 D. 其中一个为假
19.设x和y均为bool量,则x || y为假的条件是( )。 A. 它们均为真 B. 其中一个为真 C. 它们均为假 D. 其中一个为假 20. 字符串”a+b=12\\n”的长度为( )。 A. 6 B. 7 C. 8 D. 9
21. 假定下列x和y均为int型变量,则不正确的赋值为( )。 A. x+=y++ B. x++=y++ C. x=++y D. ++x=++y 22. 下列的符号常量定义中,错误的定义是( )。 A. const M=10; B. const int M=20;
C. const char ch; D. const bool mark=true;
23. 循环语句“for(int i=0; i A. 1 B. n-1 C. n D. n+1 24. 在下面循环语句中循环体执行的次数为( )。 for(int i=0; i A. n/2 B. n/2+1 C. n/2-1 D. n-1 25. 在下面循环语句中内层循环体S语句的执行总次数为( )。 for(int i=0; i for(int j=i; j 2 A. n B. (n+1)/2 C. n(n-1)/2 D. n(n+1)/2 26. 在下面循环语句中循环体执行的次数为( )。 int i=0,s=0; while(s<20) {i++; s+=i;} A. 4 B. 5 C. 6 D. 7 27. 在下面循环语句中循环体执行的次数为( )。 int i=0; do i++; while(i*i<10); A. 4 B. 3 C. 5 D. 2 28. 当处理特定问题时的循环次数已知时,通常采用( )来解决。 A. for循环 B. while循环 C. do循环 D. switch语句 29. 循环体至少被执行一次的语句为( )。 A. for循环 B. while循环 C. do循环 D. 任一种循环 30. switch语句能够改写为( )语句。 A. for B. if C. do D. while 31. do语句能够改写为( )语句。 A. 复合 B. if C. switch D. while 32. 在下面的一维数组定义中,哪一个有语法错误。( ) A. int a[]={1,2,3}; B. int a[10]={0}; C. int a[]; D. int a[5]; 33. 在下面的字符数组定义中,哪一个有语法错误。( )。 A. char a[20]=”abcdefg”; B. char a[]=”x+y=55.”; C. char a[15]; D. char a[10]=’5’; 34. 在下面的二维数组定义中,正确的是( )。 A. int a[5][]; B. int a[][5]; C. int a[][3]={{1,3,5},{2}}; D. int a[](10); 35. 假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[1][2]的值为( )。 A. 2 B. 4 C. 6 D. 8 36. 假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[2][1]的值为( )。 A. 0 B. 4 C. 8 D. 6 37. 若定义了函数 double *function(), 则函数function的返回值为( )。 A. 实数型 B.实数的地址 C.指向函数的指针 D.函数的地址 38. 以下说法中正确的是( )。 A. C++程序总是从第一个定义的函数开始执行 B. C++程序总是从main函数开始执行 C. C++函数必须有返回值,否则不能使用函数 D. C++程序中有调用关系的所有函数必须放在同一个程序文件中 39. 以下叙述中不正确的是( )。 A. 在一个函数中,可以有多条return语句 B. 函数的定义不能嵌套,但函数的调用可以嵌套 C. 函数必须有返回值 D. 不同的函数中可以使用相同名字的变量 40. 函数重载是指( )。 A. 两个或两个以上的函数取相同的函数名,但形参的个数或类型不同 B. 两个以上的函数取相同的名字和具有相同的参数个数,但形参的类型可以不同 C. 两个以上的函数名字不同,但形参的个数或类型相同 D. 两个以上的函数取相同的函数名,并且函数的返回类型相同 41. 以下关于函数模板叙述正确的是( )。 A. 函数模板也是一个具体类型的函数 B. 函数模板的类型参数与函数的参数是同一个概念 C. 通过使用不同的类型参数,函数模板可以生成不同类型的函数 D. 用函数模板定义的函数没有类型 42. 下列( )的调用方式是引用调用。 A. 形参和实参都是变量 B.形参是指针,实参是地址值 C. 形参是引用,实参是变量 D.形参是变量,实参是地址值 43. 为了提高程序的运行速度,可将不太复杂的功能用函数实现,此函数应选择( )。 A. 内联函数 B.重载函数 C.递归函数 D.函数模板 44. 函数原型语句正确的是( )。 A. int Function(void a); B.void Function (int); C. int Function(a); D.void int(double a); 45. C++中函数返回值的类型是由( )决定的。 A. return语句中表达式的类型 B.该函数定义时的类型 C.调用函数时的调用语句 D.系统根据结果 46. 以下函数的返回结果是( )。 int function(char *x) { char *p=x; while(*p++); return(p-x-1); } A. 求字符串的长度 B.将字符串x连接到字符串p后面 C. 将字符串x复制到字符串p中 D.将字符串x反向存放 47. 函数调用func((exp1,exp2),(exp3,exp4,exp5))中所含实参的个数为( )个。 A. 1 B. 2 C. 4 D. 5 48. 设有如下函数定义 int f(char *s) { char *p=s; while(*p!=’\\0’) p++; return(p-s); } 在主函数中用cout< A. 用户调用标准库函数前,必须重新定义 B. 用户可以重新定义标准库函数,若如此,该函数将失去原有含义 C. 系统不允许用户重新定义标准库函数 D. 用户调用标准库函数前,不必使用预编译命令将该函数所在文件包括到用户源文件中 51. 函数调用不可以( )。 A. 出现在一个表达式中 B. 出现在执行语句中 C. 作为一个函数的实参 D. 作为一个函数的形参 52. 以下正确的描述是( )。 A. 函数的定义可以嵌套,函数的调用不可以嵌套 B. 函数的定义不可以嵌套,函数的调用可以嵌套 C. 函数的定义和函数的调用均可以嵌套 D. 函数的定义和函数的调用均不可以嵌套 53. 若用数组名作为函数调用的实参,传递给形参的是( )。 A. 数组的首地址 B. 数组中第一个元素的值 C. 数组全部元素的值 D. 数组元素的个数 54. 以下错误的描述是( )。 A. 被调用函数中可以不用return语句 B. 被调用函数中可以用多个return语句 C. 被调用函数中,如果有返回值,就一定要有return语句 D. 被调用函数中,一个return语句可返回多个值给调用函数 55. 以下正确的描述是( )。 A. 不允许设置参数的默认值 B. 设置参数的默认值只能在定义函数时设置 C. 设置参数的默认值时,应该设置右边的参数 D. 设置参数的默认值时,应该全部参数都设置 56. 采用重载函数的目的是( )。 A. 实现共享 B. 减少空间 C. 提高速度 D. 使用方便,提高可读性 57. 将两个字符串连接起来组成一个字符串时,选用( )函数。 A. strlen() B. strcap() C. strcat() D. strcmp() 58. 以下叙述中正确的是( )。 A. 使用#define可以为常量定义一个名字,该名字在程序中可以再赋另外的值 B. 使用const定义的常量名有类型之分,其值在程序运行时是不可改变的 C. 在程序中使用内联函数使程序的可读性变差 D. 在定义函数时可以在形参表的任何位置给出缺省形参值 59. 下面的标识符中,( )是文件级作用域。 A. 函数形参 B.语句标号 C.外部静态类标识符 D.自动类标识符 60. 以下叙述不正确的是( )。 A. 宏替换不占用运行时间 B. 宏名无类型 C. 宏替换只是字符替换 D. 宏名必须用大写字母表示 61. C++语言的编译系统对宏命令的处理是( )。 A. 在程序运行时进行 B. 在程序连接时进行 C. 和C++程序的其它语句同时进行编译 D. 在对源程序中其它成分正式编译之前进行 62. 当#include后面的文件名用双引号括起来时,寻找被包含文件的方式是( )。 A. 直接按系统设定的标准方式搜索目录 B. 先在源程序所在目录搜索,再按系统设定的标准方式搜索目录 C. 仅仅搜索源程序所在目录 D. 搜索当前逻辑盘上的所有目录 63. 当#include后面的文件名用尖括号括起来时,寻找被包含文件的方式是( )。 A. 直接按系统设定的标准方式搜索目录 B. 先在源程序所在目录搜索,再按系统设定的标准方式搜索目录 C. 仅仅搜索源程序所在目录 D. 搜索当前逻辑盘上的所有目录 64. 在下面存储类中, ( ) 对象的可见性与生存期不一致。 A. 外部类 B. 自动类 C. 内部静态类 D. 寄存器类 65. 在下面存储类中,( )的对象不是局部变量。 A. 外部静态类 B. 自动类 C. 函数形参 D. 寄存器类 66. 关于局部变量,下面说法正确的是( )。 A. 定义该变量的程序文件中的函数都可以访问 B. 定义该变量的函数中的定义处以下的任何语句都可以访问 C. 定义该变量的复合语句中的定义处以下的任何语句都可以访问 D. 定义该变量的函数中的定义处以上的任何语句都可以访问 67. 文件包含命令中被包含的文件的扩展名( )。 A. 必须是.h B. 不能是.h C. 可以是.h或.cpp D. 必须是.cpp 68. 预处理命令在程序中都是以( )符号开头的。 A. * B. # C. & D. @ 69. 设array为一个数组,则表达式sizeof(array)/sizeof(array[0])的结果为( )。 A. array数组首地址 B. array数组中元素个数 C. array数组中每个元素所占的字节数 D. array数组占的总字节数 70. 用new运算符创建一个含10个元素的一维整型数组的正确语句是( )。 151. 假定一个类AB只含有一个整型数据成员a,当用户不定义任何构造函数时,系统为该类定义的无参构造函数为( )。 A. AB() {a=0;} B. AB(int aa=0): a(aa) {} C. AB(int aa): a(aa) {} D. AB() {} 152. 假定一个类AB只含有一个整型数据成员a,用户为该类定义的带参构造函数可以为( )。 A. AB() {} B. AB(): a(0){} C. AB(int aa=0) {a=aa;} D. AB(int aa) {} 153. 对于任一个类,用户所能定义的构造函数的个数至多为( )。 A. 0 B. 1 C. 2 D. 任意个 154. 对于任一个类,用户所能定义的析构函数的个数至多为( )。 A. 0 B. 1 C. 2 D. 任意个 155. 假定AB为一个类,则执行 “AB *px=new AB[n];”语句时将( )。 A. 动态分配一个数组 B. 动态分配一个对象 C. 静态分配一个数组 D. 静态分配一个对象 156. 设px是指向一个类对象的指针变量,则执行 “delete px;”语句时,将自动调用该类的( )。 A. 无参构造函数 B. 带参构造函数 C. 析构函数 D. 拷贝构造函数 157. 当一个类对象离开它的作用域时,系统自动调用该类的( )。 A. 无参构造函数 B. 带参构造函数 C. 拷贝构造函数 D. 析构函数 158. 假定一个类对象数组为A[n],当离开它定义的作用域时,系统自动调用该类析构函数的次数为( )。 A. 0 B. 1 C. n D. n-1 159. 假定AB为一个类,则执行 “AB a[10];”语句时调用该类无参构造函数的次数为( )。 A. 0 B. 1 C. 9 D. 10 160. 假定AB为一个类,则执行 “AB *px=new AB[n];”语句时调用该类无参构造函数的次数为( )。 A. n B. n-1 C. 1 D. 0 161. 假定AB为一个类,则执行 “AB a, b(3), *p;”语句时共调用该类构造函数的次数为( )。 A. 2 B. 3 C. 4 D. 5 162. 假定AB为一个类,则执行 “AB a(2), b[3], *p[4];”语句时共调用该类构造函数的次数为( )。 A. 3 B. 4 C. 5 D. 9 163. 假定AB为一个类,则执行“AB a, b(2), c[3], *p=&a;”语句时共调用该类无参构造函数的次数为( )。 A. 5 B. 6 C. 3 D. 4 164. 假定AB为一个类,则执行“AB *p=new AB(1,2);”语句时共调用该类构造函数的次数为( )。 A. 0 B. 1 C. 2 D. 3 165. 假定AB为一个类,px为指向该类的一个含有n个对象的动态数组的指针,则执行“delete []px;”语句时共调用该类析构函数的次数为( )。 A. 0 B. 1 C. n D. n+1 166. 对类对象成员的初始化是通过构造函数中给出的( )实现的。 A. 函数体 B. 初始化表 C. 参数表 D. 初始化表或函数体 167. 对类中常量成员的初始化是通过构造函数中给出的( )实现的。 A. 函数体 B. 参数表 C. 初始化表 D. 初始化表或函数体 168. 对类中引用成员的初始化是通过构造函数中给出的( )实现的。 A. 函数体 B. 参数表 C. 初始化表 D. 初始化表或函数体 169. 类的构造函数可以带有( )个参数。 A. 0 B. 1 C. 2 D. 任意 170. 类的析构函数可以带有( )个参数。 A. 0 B. 1 C. 2 D. 任意 171. 一个类的静态数据成员所表示属性 ( )。 A. 是类的或对象的属性 B. 只是对象的属性 C. 只是类的属性 D. 类和友元的属性 172. 类的静态成员的访问控制( )。 A. 只允许被定义为private B. 只允许被定义为private或protected C. 只允许被定义为public D. 可允许被定义为private、protected或public 173. 静态成员函数对类的数据成员访问( )。 A. 是不允许的 B. 只允许是静态数据成员 C. 只允许是非静态数据成员 D. 可允许是静态数据成员或非静态数据成员 174. 被非静态成员函数访问的类的数据成员( )。 A. 可以是非静态数据成员或静态数据成员 B. 不可能是类的静态数据成员 C. 只能是类的非静态数据成员 D. 只能是类的静态数据成员 175. 静态数据成员的初始化是在( )中进行的。 A. 构造函数 B. 任何成员函数 C. 所属类 D. 全局区 176. 当将一个类A或函数f()说明为另一个类B的友元后,类A或函数f()能够直接访问类B的( )。 A. 只能是公有成员 B. 只能是保护成员 C. 只能是除私有成员之外的任何成员 D. 具有任何权限的成员 177. 引入友元的主要目的是为了( )。 A. 增强数据安全性 B. 提高程序的可靠性 C. 提高程序的效率和灵活性 D. 保证类的封装性 178. 一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明( )。 A. 需加上类域的限定 B. 不需加上类域的限定 C. 类域的限定可加可不加 D. 不需要任何限定 179. 一个类的友元不是该类的成员,与该类的关系密切,所以它( )。 A. 有this指针,有默认操作的对象 B. 没有this指针,可以有默认操作的对象 C. 有this指针,不能执行默认操作 D. 没有this指针,也就没有默认操作的对象 180. 在重载一个运算符时,其参数表中没有任何参数,这表明该运算符是( )。 A. 作为友元函数重载的1元运算符 B. 作为成员函数重载的1元运算符 C. 作为友元函数重载的2元运算符 D. 作为成员函数重载的2元运算符 181. 在成员函数中进行双目运算符重载时,其参数表中应带有( )个参数。 A. 0 B. 1 C. 2 D. 3 182. 双目运算符重载为普通函数时,其参数表中应带有( )个参数。 A. 0 B. 1 C. 2 D. 3 183. 如果表达式a+b中的“+”是作为成员函数重载的运算符,若采用运算符函数调用格式,则可表示为( )。 A. a.operator+(b) B. b.operator+(a) C. operator+(a,b) D. operator(a+b) 184. 如果表达式a==b中的“==”是作为普通函数重载的运算符,若采用运算符函数调用格式,则可表示为( )。 A. a.operator==(b) B. b.operator==(a) C. operator==(a,b) D. operator==(b,a) 185. 如果表达式a++中的“++”是作为普通函数重载的运算符,若采用运算符函数调用格式,则可表示为( )。 A. a.operator++() B. operator++(a) C. operator++(a,1) D. operator++(1,a) 186. 如果表达式++a中的“++”是作为成员函数重载的运算符,若采用运算符函数调用格式,则可表示为( )。 A. a.operator++(1) B. operator++(a) C. operator++(a,1) D. a.operator++() 187. 关于运算符重载,下列说法正确的是( )。 A. 重载时,运算符的优先级可以改变。 B. 重载时,运算符的结合性可以改变。 C. 重载时,运算符的功能可以改变。 D. 重载时,运算符的操作数个数可以改变。 188. 关于运算符重载,下列说法正确的是( )。 A. 所有的运算符都可以重载。 B. 通过重载,可以使运算符应用于自定义的数据类型。 C. 通过重载,可以创造原来没有的运算符。 D. 通过重载,可以改变运算符的优先级。 189. 一个程序中数组a和变量k定义为“int a[5][10],k;”,且程序中包含有语句“a(2,5)=++k*3;”,则此语句中肯定属于重载操作符的是( )。 A. ( ) B. = C. ++ D. * 190. 假定K是一个类名,并有定义“K k; int j;”,已知K中重载了操作符 ( ),且语句“j=k(3);”和“k(5)=99;”都能顺利执行,说明该操作符函数的原形只可能是( )。 A. K operator ( ) (int); B. int operator ( )(int&); C. int & operator ( )(int); D. K &operator( )(int); 191. 假定M是一个类名,且M中重载了操作符=,可以实现M对象间的连续赋值,如“m1=m2=m3;”。重载操作符=的函数原型最好是( )。 A. int operaotor=(M); B. int operator=(M&); C. M operator=(M&); D. M& operator=(M); 192. 下面是重载双目运算符+的普通函数原形,其中最符合+原来含义的是( )。 A. Value operator+(Value, Value); B. Value operator+(Value,int); C. Value &operator+(Value, Value); D. Value &operator+(Value&, Value&); 193. 下面是重载双目运算符-的成员函数原形,其中最符合-原来含义的是( )。 A. Value Value::operator-(Value); B. Value Value::operator-(int); C. Value& Value::operator-(Value); D. Value& Value::operator-(Value&); 194. 在重载一运算符时,若运算符函数的形参表中没有参数,则不可能的情况是( )。 A. 该运算符是一个单目运算符。 B. 该运算符函数有一个隐含的参数this。 C. 该运算符函数是类的成员函数。 D. 该运算符函数是类的友元函数。 195. 关于插入运算符<<的重载,下列说法不正确的是( )。 A. 运算符函数的返回值类型是ostream & 。 B. 重载的运算符必须定义为类的成员函数。 C. 运算符函数的第一个参数的类型是ostream & 。 D. 运算符函数有两个参数。 196. 从一个基类派生出的各个类的对象之间( )。 A. 共享所有数据成员,每个对象还包含基类的所有属性 B. 共享部分数据成员,每个对象还包含基类的所有属性 C. 不共享任何数据成员,但每个对象还包含基类的所有属性 D. 共享部分数据成员和函数成员 197. 如果是类B在类A的基础上构造,那么,就称( )。 A. 类A为基类或父类,类B为超类或子类 B. 类A为基类、父类或超类,类B为派生类或子类 C. 类A为派生类,类B为基类 D. 类A为派生类或子类,类B为基类、父类或超类 198. C++的继承性允许派生类继承基类的( )。 A. 部分特性,并允许增加新的特性或重定义基类的特性 B. 部分特性,但不允许增加新的特性或重定义基类的特性 C. 所有特性,并允许增加新的特性或重定义基类的特性 D. 所有特性,但不允许增加新的特性或重定义基类的特性 199. 派生类的成员函数可以直接访问基类的( )成员。 A. 所有 B. 公有和保护 C. 保护和私有 D. 私有 200. 对于公有继承,基类的公有和保护成员在派生类中将( )成员。 A. 全部变成公有 B. 全部变成保护 C. 全部变成私有 D. 仍然相应保持为公有和保护 201. 对于公有继承,基类中的私有成员在派生类中将 ( )。 A. 能够直接使用成员名访问 B. 能够通过成员运算符访问 C. 仍然是基类的私有成员 D. 变为派生类的私有成员 202. 当保护继承时,基类的( )在派生类中成为保护成员,在类作用域外不能够通过派生类的对象来直接访问该成员。 A. 任何成员 B.公有成员和保护成员 C. 保护成员和私有成员 D.私有成员 203. 在定义一个派生类时,若不使用保留字显式地规定采用何种继承方式,则默认为( )方式。 A. 私有继承 B. 非私有继承 C. 保护继承 D. 公有继承 204. 建立包含有类对象成员的派生类对象时,自动调用构造函数的执行顺序依次为( )的构造函数。 A. 自己所属类、对象成员所属类、基类 B. 对象成员所属类、基类、自己所属类 C. 基类、对象成员所属类、自己所属类 D. 基类、自己所属类、对象成员所属类 205. 当派生类中有和基类一样名字的成员时,一般来说,( )。 A. 将产生二义性 B. 派生类的同名成员将覆盖基类的成员 C. 是不能允许的 D. 基类的同名成员将覆盖派生类的成员 206. C++中的虚基类机制可以保证:( )。 A. 限定基类只通过一条路径派生出派生类 B. 允许基类通过多条路径派生出派生类,派生类也就能多次继承该基类 C. 当一个类多次间接从基类派生以后,派生类对象能保留多份间接基类的成员 D. 当一个类多次间接从基类派生以后,其基类只被一次继承 207. 下列对派生类的描述中错误的说法是:( )。 A. 派生类至少有一个基类 B. 派生类可作为另一个派生类的基类 C. 派生类除了包含它直接定义的成员外,还包含其基类的成员 D. 派生类所继承的基类成员的访问权限保持不变 208. 派生类的对象对其基类中( )可直接访问。 A. 公有继承的公有成员 B. 公有继承的私有成员 C. 公有继承的保护成员 D. 私有继承的公有成员 二、判断题 1.C++中标识符内的大小写字母是没有区别的。(F ) 2.C++是一种以编译方式实现的高级语言。(T ) 3.计算函数参数顺序引起的二义性是由不同的编译系统决定的。(T ) 4.返回值类型、参数个数和类型都相同的函数也可以重载。(F ) 5.使用关键字class定义的类中缺省的访问权限是私有(private)的。(T ) 6.类的私有成员只能被类中的成员函数访问,任何类以外的函数对它们的访问都是非法的。(F ) 7.多继承情况下,派生类的构造函数的执行顺序取决于成员初始化列表中的顺序。(F ) 8.在公有继承中,基类中的公有成员和私有成员在派生类中都是可见的。(F ) 9.在私有继承中,基类中所有成员对派生类都是不可见的。(F ) 10.在保护继承中,对于垂直访问等同于公有继承,对于水平访问等同于私有继承。(T ) 11.构造函数可以声明为虚函数。(F ) 12.在析构函数中调用虚函数时,采用动态束定。(F ) 13.在一个成员函数内调用一个虚函数时,对该虚函数的调用进行动态束定。(T ) 14.公有继承可以实现子类型。(T ) 15.构造函数可以声明为纯虚函数。(F ) 16.说明函数原型时不需要指明每个函数参数的名字,只需要说明每个参数的类型和返回值类型就可以了。对 17.所有的表达式都有值。错 18.程序的编译是以文件为单位的,因此将程序分到多个文件中可以减少每次对程序修改所 带来的编译工作量。对 19.类的静态数据成员需要在定义每个类的对象时进行初始化。错 20.基类中被说明为protected和private的成员只能被其派生类的成员函数访问,不能被 其它的函数访问。错 21.当将一个类S定义为另一个类A的友元类时,类S的所有成员函数都可以直接访问类A 的所有成员。对 22.当函数的返回值是数组类型的,传递的是数组第一个元素的地址。错 23.如果派生类的成员函数的原型与基类中被定义为虚函数的成员函数原型相同,那么,这 个函数自动继承基类中虚函数的特性。对 24.字符串’hello,world”在内存中存放时,占用11个字节的空间。错 25.用new动态申请的内存空间,必须用delete来释放 。对 26.静态数据成员必须在类外定义和初始化。( √ ) 27.保护继承时,派生类中的成员函数可以直接访问基类中的protected成员。(√ ) 28.静态成员函数可以引用属于该类的任何函数成员。( × ) 29.指针常量可以指向相应类型的常量。(√ ) 30.友元函数是在类声明中由关键字friend修饰说明的类的成员函数。( × ) 31.如果程序中未声明构造函数,则系统自动产生出一个默认形式的构造函数。( √ ) 32.友元函数访问对象中的成员可以不通过对象名( × ) 33.如果程序中未声明析构函数,编译器将自动产生一个默认的析构函数。(√ ) 34.类中的成员数据可以是另一个类的对象。( √ ) 35.常引用做形参,在函数中不能更新所引用的对象。(√) 36.虚函数不能是类的静态成员。对 37.重定义虚函数的派生类必须是公有继承的。对 38.对于从基类继承的虚函数,派生类也可以不进行重定义。对 39.纯虚函数与函数体为空的虚函数等价。错 40.多态类提供了一种动态多分支派送机制。对 41.作为虚函数隐含参数的this指针,决定了虚函数调用时执行的代码。对 三、填空题 1. C++语言是在_________语言的基础上发展起来的。 2. C++语言的编译单位是扩展名为__________的__________文件。 3. 行尾使用注释的开始标记符为__________。 4. 多行注释的开始标记符和结束标记符分别为__________和__________。 5. 用于输出表达式值的标准输出流对象是_________。 6. 用于从键盘上为变量输入值的标准输入流对象是________。 7. 一个完整程序中必须有一个名为________的函数。 8. 一个函数的函数体就是一条_________语句。 9. 当执行cin语句时,从键盘上输入每个数据后必须接着输入一个________符,然后才能继续输入下一个数据。 10. 在C++程序中包含一个头文件或程序文件的预编译命令为__________。 11. 程序中的预处理命令是指以______字符开头的命令。 12. 一条表达式语句必须以______作为结束符。 13. 在#include命令中所包含的头文件,可以是系统定义的头文件,也可以是________定义的头文件。 14. 使用#include命令可以包含一个头文件,也可以包含一个______文件。 15.一个函数定义由________和________两部分组成。 16.若一个函数的定义处于调用它的函数之前,则在程序开始可以省去该函数的______语句。 17.C++头文件和源程序文件的扩展名分别为______和______。 18.程序文件的编译错误分为________和________两类。 19.当使用_______保留字作为函数类型时,该函数不返回任何值。 20.当函数参数表用______保留字表示时,则表示该参数表为空。 21.从一条函数原型语句“int fun1(void);”可知,该函数的返回类型为______,该函数带有______个参数。 22. 当执行cout语句输出endl数据项时,将使C++显示输出屏幕上的光标从当前位置移动到________的开始位置。 23. 假定x=5,y=6,则表达式x++*++y的值为__________。 24. 假定x=5,y=6,则表达式x--*--y的值为__________。 25. 假定x=5,y=6,则执行表达式y*=x++计算后,x和y的值分别为__________和__________。 26. 假定x=5,y=6,则执行表达式y+=x--计算后,x和y的值分别为__________和__________。 27. C++常数0x145对应的十进制值为__________。 28. C++常数0345对应的十进制值为__________。 29. 十进制常数245对应的十六进制的C++表示为__________。 30. 十进制常数245对应的八进制的C++表示为__________。 31. signed char类型的值域范围是________至__________之间的整数。 32. int和float类型的数据分别占用_________和__________个字节。 33. float和double类型的数据分别占用_________和________个字节。 34. bool和char类型的数据分别占用_________和________个字节。 35. unsigned short int和int类型的长度分别为_________和________。 36. 字符串”This\\’s a book.\\n”的长度为__________。 37. 字符串”\\nThis\\’s a pen\\n\\n”的长度为__________。 38. 在C++中存储字符串”abcdef”至少需要________个字节。 39. 在C++中存储字符串”a+b=c”至少需要________个字节。 40. 假定x和y为整型,其值分别为16和5,则xy和x/y的值分别为__________和__________。 41. 假定x和y为整型,其值分别为16和5,则x/y和double(x)/y的值分别为__________和__________。 42. 假定x是一个逻辑量,则x true的值为__________。 43. 假定x是一个逻辑量,则x || true的值为__________。 44. 假定x是一个逻辑量,则x false的值为__________。 45. 假定x是一个逻辑量,则x || false的值为__________。 46. 假定x是一个逻辑量,则!x || false的值为__________。 47. 假定x是一个逻辑量,则x !x的值为__________。 48. 假定x是一个逻辑量,则x || !x的值为__________。 49. 数学算式 x?y 的C++表达式为________________。 2xy3xy 的C++表达式为________________。 x?y1的C++表达式为________________。 22ax?by50. 数学算式 51. 数学算式 52. 设enum Printstatus{ready,busy,error}; 则 cout< 53. 设enum Printstatus{ready=2,busy,error}; 则cout< 54. 常数-4.205和6.7E-9分别具有__________和__________位有效数字。 55. 枚举类型中的每个枚举值都是一个__________,它的值为一个__________。 56. 常数100和3.62的数据类型分别为__________和__________。 57. 若x=5, y=10, 则计算y*=++x表达式后,x和y的值分别为______和______。 58. 假定x和ch分别为int型和char型,则sizeof(x)和sizeof(ch)的值分别为______和______。 59. 假定x=10,则表达式x<=10?20:30的值为______。 60. 表达式sqrt(81)和pow(6,3)的值分别为______和______。 61. 含随机函数的表达式rand()20的值在_____至______区间内。 62. 在switch语句中,每个语句标号所含关键字case后面的表达式必须是_______。 63. 在if语句中,每个else关键字与它前面同层次并且最接近的________关键字相配套。 64. 作为语句标号使用的C++保留字case和defaule只能用于________语句的定义体中。 65. 执行switch语句时,在进行作为条件的表达式求值后,将从某个匹配的标号位置起向下执行,当碰到下一个标号位置时(停止/不停止)________执行。 66. 若while循环的“头”为“while(i++<=10)”,并且i的初值为0,同时在循环体中不会修改i的值,则循环体将被重复执行______次后正常结束。 67. 若do循环的“尾”为“while(++i<10)”,并且i的初值为0,同时在循环体中不会修改i的值,则循环体将被重复执行______次后正常结束。 68. 当在程序中执行到________语句时,将结束本层循环类语句或switch语句的执行。 69. 当在程序中执行到________语句时,将结束所在循环语句中循环体的一次执行。 70. 在程序中执行到________语句时,将结束所在函数的执行过程,返回到调用该函数的位置。 71.在程序执行完________函数调用后,将结束整个程序的执行过程,返回到C++集成开发窗口。 72. 元素类型为int的数组a[10]共占用________字节的存储空间。 73. 元素类型为double的二维数组a[4][6]共占用________字节的存储空间。 74. 元素类型为char的二维数组a[10][30]共占用________字节的存储空间。 75. 存储字符’a’和字符串”a”分别需要占用________和________个字节。 76. 空串的长度为________,存储它需要占用________个字节。 77. 字符串”\\’a\\’xy=4\\n”的长度为________。 78. 字符串”a:\\\\xxk\\\\数据”的长度为________。 79. 用于存储一个长度为n的字符串的字符数组的长度至少为________。 80. 若a是一个字符数组,则从键盘上向该数组输入一个字符串的表达式为__________。 81. 若a是一个字符数组,则向屏幕输出a中所存字符串的表达式为__________。 82. 一个二维字符数组a[10][20]能够存储________个字符串,每个字符串的长度至多为________。 83. 对一个二维字符数组a进行初始化的数据为{”123”,”456”,”789”},则a[1]元素对应的字符串为__________。 84. strlen(”apple”)的值为________,strcmp(”a”,”A”)的值为________。 85. 若需要把一个字符串”aaa”赋值到字符数组a中,则需要执行________函数的调用来实现。 85. 假定对数组a[]进行初始化的数据为{2,7,9,6,5,7,10},则a[2]和a[5]分别被初始化为________和________。 86. 假定对二维数组a[3][4]进行初始化的数据为{{3,5,6},{2,8},{7}},则a[1][1]和a[2][3]分别被初始化为_______和________。 87. 在C++语言中,一个函数由函数头和__________组成。 88. 重载一个函数的条件是:该函数必须在参数的个数或参数的__________上与其它同名函数有所不同。 89. 如果一个函数只允许同一程序中的函数调用,则应在该函数定义前加上__________C++保留字。 90. 若“double x=100;”是文件F1.CPP中的一个全局变量定义语句,若文件F2.CPP 中的某个函数需要访问此x , 则应在文件F2.CPP中添加对x的声明语句为_________________。 91. 定义一个函数模板要用到的第一个修饰符是____________。 92. 在函数模板的参数中,用class修饰的参数称为__________参数。 93. 如果一个函数直接或间接地调用自身,这样的调用称为____________调用。 94. 已知int cubin(int n){return n*n*n;}和double cubin(double n){return n*n*n;}是一个函数模板的两个实例,假定类型参数用T表示,则该函数模板的定义是__________________________________。 95. 对于无返回值函数,定义函数时要用__________修饰函数类型。 96. 如果一个函数定义中使用了__________修饰,则该函数不允许被其它文件中的函数调用。 97. 如果一个函数中有多个默认参数,则默认参数必须全部处在形参表的________部分。 98. 定义外部变量时,不用存储类说明符_________,而声明外部变量时用它。 99.调用系统函数时,要先使用#include命令包含该系统函数的原型语句所在的__________。 100. 函数形参的作用域是该函数的____________。 101. C++提供的预处理命令有宏定义命令,条件编译命令和____________。 102. 程序的编译是以__________为单位进行的。 103. C++程序运行时的内存空间可以分成全局数据区,堆区,栈区和__________。 104. 全局变量和静态局部变量具有静态生存期,存放在内存的____________区中。 105. 局部变量具有局部生存期,存放在内存的____________区中。 106. 若二维数组a有m列,设a[0][0]位于数组的第一个位置上,则计算任一元素a[i][j]在数组中位置序号的公式为____________。 107. 若有定义“double a[3][5];”,则a 数组中行下标和列下标的最大值分别为________和________。 108. 若有定义“struct AA {int a; char b; double c;}x;”,则x占用空间大小为________字节。 109. 当定义一个结构体变量时,系统分配给该变量的内存大小等于各成员所需内存大小的_______。 110. 一个指针类型的对象占用内存的________个字节的存储空间。 111. 一个指针指向一个数据对象,它保存着该数据对象的________,若数据对象为DataType类型,则相应的指针类型为__________。 112. 若要把一个整型指针p转换为字符指针,则采用的强制转换表达式为________。 113. 假定一个数据对象为int*类型,则指向该对象的指针类型为_______。 114. 假定p是一个指向整数对象的指针,则用________表示该整数对象,用________表示指针变量p的地址。 115. 假定p是一个指针,则*p++运算首先访问________,然后使________的值增1。 116. 假定p是一个指针,则(*p)++运算首先访问________,然后使________的值增1。 117. 假定p所指对象的值为25,p+1所指对象的值为42,则*p++的值为________。 118.假定p所指对象的值为25,p+1所指对象的值为42,则*++p的值为________。 119. 假定p所指对象的值为25,p+1所指对象的值为42,则执行(*p)++运算后,p所指对象的值为________。 120.假定p所指对象的值为25,p+1所指对象的值为42,则执行*(p++)或*p++运算后,p所指对象的值为________。 121.假定a是一个一维指针数组,则a+i所指对象的地址比a大________字节。 122. 假定a是一个一维数组,则a[i]的指针访问方式为________。 123. 假定a是一个一维数组,则a[i]对应的存储地址(以字节为单位)为 ____________。 124. 一个数组的数组名实际上是指向该数组________元素的指针,并且在任何时候都不允许________它。 125. 假定指向一维数组b[10]中元素b[4]的指针为p,则p+3所指向的元素为_______,p-2所指向的元素为________。 126.若要定义整型指针p并初始指向x,则所使用的定义语句为________。 127. 若p指向x,则________与x的表示是等价的。 128. 在一个二维数组int a[m][n]中,包含的一维元素a[i]的类型为________,访问a[i]时返回值的类型为________。 129. 假定一个二维数组为c[5][8],则c[3]的值为二维元素________的地址,c[3]+2的值为二维元素________的地址。 130. 假定p为指向二维数组int d[4][6]的指针,则p的类型为________。 131. 假定a是一个二维数组,则a[i][j]的指针访问方式为____________。 132. 若要把整型变量y定义为x的引用,则所使用的定义语句为________。 133. 若y是x的引用,则对y的操作就是对_______的操作。 134. 若y是x的引用,则y和x的值________,即为变量________的地址。 135. 执行int p=new int操作得到的一个动态分配的整型对象为________。 136. 执行int *p=new int[10]操作,使p指向动态分配的数组中下标为0的元素,该元素可表示为_______或________。 137. 执行char *p=new char(’a’)操作后,p所指向的数据对象的值为________。 138. 执行new char[m][n]操作时的返回值的类型为________。 139. 执行________操作将释放由p所指向的动态分配的数据空间。 140. 执行________操作将释放由p所指向的动态分配的数组空间。 141. NULL是一个符号常量,通常作为空指针值,它的具体值为________。 142. 变量v定义为“double v=23.4;”,要使指针pv指向v,则定义pv的语句为______________。 143. 已知语句“cout< 144. 已知语句“cout< 145. 指针变量pv和pc定义为“void *pv =”Hello, word!”; char *pc;”,要将pv值赋给pc,则正确的赋值语句是_______________。 145. 数组a定义为“int a[100];”,要使p[j] 与a[j] 等效,则指针p应定义为______________。int *p=a; (或int *p=a[0];) 146. 数组b定义为“int b[20][100];”,要使p[j][k] 与b[j][k] 等效,则指针p应定义为__________________。 147. 与结构成员访问表达式p->name等价的表达式是____________。 148. 与结构成员访问表达式(*fp).score等价的表达式是____________。 149. 已知变量a定义为“int a=5;”,要使ra成为a的引用,则ra应定义为____________。 150. 已知有定义“int x, a[]={5,7,9}, *pa=a;”,在执行“x=++*pa;”语句后,x的值是________。 151.已知有定义“int x, a[]={6,10,12}, *pa=a;”,在执行“x=*++pa;”语句后,*pa的值是________。 152. 已知有定义“int x, a[]={15,17,19}, *pa=a;”,在执行“x=*pa++;”后,*pa的值是________。 153. 以面向对象方法构造的系统,其基本单位是__________。 154. 每个对象都是所属类的一个__________。 155. 对象将其大部分实现细节隐藏起来,这种机制称为__________。 156. 基类和派生类的关系称为__________。 157. 复杂对象可以由简单对象构成,这种现象称为__________。 158. 对象是对问题域中客观事物的________,它是一组属性和在这些属性上操作的__________。 159. 特殊类的对象拥有其一般类的全部属性与操作,称特殊类________了一般类。 160. 如果一个派生类的基类不止一个,则这种继承称为____________。 161. 如果一个派生类只有一个唯一的基类,则这样的继承关系称为__________。 162. C++支持两种多态性:_________时的多态性和__________时的多态性。 163. 在C++中,编译时的多态性是通过__________实现的,而运行时的多态性则是通过__________实现的。 164. 面向对象软件开发的生命周期分为三个阶段,即分析、__________和__________。 165. 面向对象的分析包括__________分析和__________分析两步。 166. 类定义中,既包含数据成员,也包含________成员。 167. 类中的数据成员的访问属性通常被指明为________。 168. 类中的供外部调用定义的函数成员,其访问属性通常被定义为________。 169. 对于类中定义的任何成员,其隐含访问权限为________。 170. 对于结构中定义的任何成员,其隐含访问权限为________。 171. 为了使类中的成员不能被类外的函数通过成员操作符访问,则应把该成员的访问权限定义为________。 172. 若在类的定义体中给出了一个成员函数的完整定义,则该函数属于________函数。 173. 若在类的定义体中只给出了一个成员函数的原型,则在类外给出完整定义时,其函数名前必须加上________和两个冒号分隔符。 174. 若在类的定义体中只给出了一个成员函数的原型,则在类外给出完整定义时,其函数名前必须加上类名和两个________分隔符。 175. 若要把类外定义的成员函数规定为内联函数,则必须把________关键字放到函数原型或函数头的前面。 176. 把一个类的定义体和所有成员函数的定义体所构成的程序范围叫做该类的____________。 177. 假定AA是一个类,“AA* abc();”是该类中一个成员函数的原型,则在类外定义时的函数头为__________________。 178. 成员函数的参数表在类作用域中,成员函数的返回值类型________类作用域中。 179. 为了避免在调用成员函数时修改对象中的任何数据成员,则应在定义该成员函数时,在函数头的后面加上________关键字。 180. 若只需要通过一个成员函数读取数据成员的值,而不需要修改它,则应在函数头的后面加上________关键字。 181. 若采用x.abc(y)表达式调用一个成员函数,在成员函数中使用的________就代表了类外的x对象。 182. 若采用p->abc(y)表达式调用一个成员函数,在成员函数中使用的________就代表了类外的p指针。 183. 内联函数的定义模块与________模块必须放在同一个文件中。 184.假定AA是一个类,“AA* abc()const;”是该类中一个成员函数的原型,在该函数体中(能够/不能够)__________向*this或其成员赋值。 185.在一个用数组实现的队列类中,包含有两个数据成员,一个指明队首元素位置,另一个指明____________。 186. 在一个用数组实现的队列类中,包含有两个数据成员,一个指明队列长度,另一个指明__________元素的位置。 187. 在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则插入一个新元素的位置为__________。 188. 在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则删除一个元素后队首的位置为__________。 189. 在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则队列为空的条件为__________。 190. 在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则队列为满的条件为__________。 191. 当一个队列为空时,不能对其做________元素的操作。 192. 当一个队列为满时,不能对其做________元素的操作。 193.从一个队列中删除元素就是删除________位置上的元素。 194.向一个队列中插入元素就是把该元素放到________元素的后一位置上。 195.在一个用链表实现的队列类中,假定每个结点包含的值域用elem表示,包含的指针域用next表示,链队的队首指针用elemHead表示,队尾指针用elemTail表示,当链队非空时,_____________指向队首结点的后继(即下一个)结点。 196. 在一个用链表实现的队列类中,假定每个结点包含的值域用elem表示,包含的指针域用next表示,链队的队首指针用elemHead表示,队尾指针用elemTail表示,当链队非空时,新插入结点的地址应当赋给___________所指结点的next域。 197. 在一个用链表实现的队列类中,队尾结点的指针域的值为________。 198. 在一个用链表实现的队列类中,若链队中只含有一个结点,则队首指针的值与队尾指针的值________。 199. 在一个用链表实现的队列类中,若链队为空或只含有一个结点,则队首指针的值与队尾指针的值________。 200. 在一个用链表实现的队列类中,若队首指针与队尾指针的值不同,则说明链队中至少包含有________个结点。 201.一个类的__________函数实现对该类对象的初始化功能。 202.一个类的__________函数通常用于实现释放该类对象中指针成员所指向的动态存储空间的任务。 203.当用户为一个类定义有____________时,则系统不会为该类再自动生成一个默认构造函数。 204.假定用户没有给一个名为AB的类定义构造函数,则系统为其定义的构造函数为__________。 205.假定用户没有给一个名为AB的类定义析构函数,则系统为其定义的析构函数为__________。 206.定义类动态对象数组时,其元素只能靠自动调用该类的____________来进行初始化。 207.在一个类中定义拷贝构造函数的目的,是为了当利用该类的一个对象初始化另一个对象时,能够避免这两个对象的同一指针同时指向同一块__________________。 208.为了释放类对象中指针成员所指向的动态存储空间,则需要为该类定义____________。 209. 假定 AB为一个类,则执行“AB a[10];”语句时,系统自动调用该类构造函数的次数为________。 210.假定一个类对象数组为A[N],当离开它的作用域时,系统自动调用该类析构函数的次数为________。 211.对类中对象成员的初始化是通过在构造函数中给出的______________来实现的。 212.对类中常量成员的初始化是通过在构造函数中给出的______________来实现的。 213.对类中引用成员的初始化只能通过在构造函数中给出的______________来实现。 214.对类中一般数据成员的初始化既可以通过在构造函数中给出的初始化表来实现, 也可以通过构造函数中的____________来实现。 215. 假定要把aa定义为AB类中的一个常量整数型数据成员,则定义语句为____________。 216. 假定要把aa定义为AB类中的一个引用整数型数据成员,则定义语句为____________。 217. 假定AB类中只包含一个整型数据成员a,并且它是一个常量成员,若利用参数aa对其进行初始化,则该类的构造函数的定义为____________________。 218. 假定AB类中只包含一个整型数据成员a,并且它是一个引用成员,若利用引用参数aa对其进行初始化,则该类的构造函数的定义为____________________。 219.假定指针p指向一个动态分配的类对象,则当执行“delete p;”语句时,在释放p所指向的动态存储空间之前将自动调用该类的____________。 220.假定用户为类AB定义了一个构造函数“AB(int aa) {a=aa;}”,则系统(会/不会)_________为该类自动定义一个无参构造函数\{}\。 221. 假定用户为类AB定义了一个构造函数“AB(int aa, char *bb=NULL):a(aa),b(bb){}”,则该类中至少包含有__________个数据成员。 222.假定用户为类AB定义了一个构造函数“AB(int aa) {a=aa;}”,该构造函数实现对数据成员_________的初始化。 223.假定用户为类AB定义了一个构造函数“AB(int aa=0):a(aa){}”,则定义该类的对象时,可以有________种不同的定义格式。 224.假定用户为类AB定义了一个构造函数“AB(int aa):a(aa){}”,则定义该类的对象时,有________种定义格式。 225.假定用户只为类AB定义了一个构造函数“AB(int aa, int bb=0) {a=aa; b=bb;}”,则定义该类的对象时,其实参表中至多带有_________个实参。 226.假定用户只为类AB定义了一个构造函数“AB(int aa, int bb=0) {a=aa; b=bb;}”,则定义该类的对象时,其实参表中至少带有_________个实参。 227.假定用户为类AB定义了一个构造函数“AB(int aa=0, int bb=0) {a=aa; b=bb;}”,则定义该类的对象时,可以有________种不同的定义格式。 228.假定用户只为类AB定义了一个构造函数“AB():a(0),b(0){}”,则定义该类对象x的定义语句“AB x();”是_________(正确/错误)的。 229.假定用户只为类AB定义了一个构造函数“AB():a(0),b(0){}”,则定义该类对象x的定义语句“AB x;”是_________(正确/错误)的。 230.假定用户只为类AB定义了一个构造函数“AB():a(0),b(0){}”,则定义该类对象x的定义语句“AB x(5);”是_________(正确/错误)的。 231.假定AB为一个类,则类定义体中的“AB(AB x);”语句为该类______________的原型语句。 232.假定AB为一个类,则该类的拷贝构造函数的函数头为_____________。 233.假定AB为一个类,该类中含有一个指向动态数组空间的指针成员pa,则在该类的析构函数中应该包含有一条______________语句。 234. 静态成员函数____访问类的静态数据成员, ____访问类的非静态数据成员。 235. 静态数据成员必须在所有函数的定义体外进行__________。 236. 一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明必须在函数名前加上__________的限定。 237. 重载运算符时,该运算符的__________、结合性以及操作符的个数不允许改变。 238. 一个单目运算符作为类的成员函数重载时有________个参数;如果作为独立函数 重载,则有________个参数。 239. 一个双单目运算符作为类的成员函数重载时有________个参数;如果作为独立函数重载,则有________个参数。 240. 除了__________运算符外,其他重载的运算符都可以被派生类继承。 241. 作为类的成员函数重载一个运算符时,参数表中只有一个参数,说明该运算符有________个操作数。 242. 在重载一个单目运算符时,参数表中没有参数,说明该运算符函数只能是类的_____________。 243. 重载插入运算符<<时,其运算符函数的返回值类型应当是____________。 244. 重载抽取运算符>>时,其运算符函数的返回值类型应当是____________。 245. 重载插入运算符<<或抽取运算符>>时,其运算符函数的参数有________个。 246. 重载插入运算符<<或抽取运算符>>时,其运算符函数不能被定义为类的________函数。 247. 类型转换函数没有____________类型,而且参数表为____________。 248. 在一个或若干个类的基础上构造一个新类,被称为___________。 249. 派生类的成员函数可以直接访问基类的__________成员,不能直接访问基类的 ______成员。 250. 当保护继承时,基类的__________成员在派生类中成为保护成员,派生类对象不能直接访问基类的__________成员。 251. 在定义一个派生类时,使用__________关键字或者不显式地使用它则表示为__________继承。 252. 若多个基类及其派生类中都定义了同名函数成员,要访问相应函数时,就需要在函数名前加上______和类区分符。 253. 若要保证一个公共的基类在派生类中只产生一个基类子对象,则必须都以____________的方式直接继承它。 254. 引进虚基类的根本目的是为了消除____________。 255. 在每个成员函数中,隐含的第一个参数的参数名为________。 四、程序填充 1. 斐波那契数列的第1和第2个数分别为0和1 ,从第三个数开始,每个数等于其前两个数之和。求斐波那契数列中的前20个数,要求每行输出5个数。 #include int f,f1,f2,i; cout<<” 斐波那契数列:\\n”; f1=0; f2=1; cout< cout< if(_____(2)______) cout< f2=____(3)_______; } cout< (1) (2) (3) 2. 计算?(?1)i?110i?1xi的值。 i! #include double x,p1=1,p2=1,s=0; int i,j=1; cout<<\输入x的值:\ cin>>x; for(i=1;i<=10;i++) { p1*=___(1)_____; p2*=____(2)____; i+1 s+=j*p1/p2; //j的值为(-1) j=____(3)____; } cout< (1) (2) (3) 3. 打印出2至99之间的所有素数(即不能被任何数整除的数)。 #include int i,n; for(n=2; ___(1)___; n++) { int temp=int(sqrt(n)); //求出n的平方根并取整 for(i=2; ___(2)___; i++) if(n%i==0) ___(3)___; if(i>temp) cout< cout<<'\\n'; } (1) (2) (3) 4. 采用辗转相除法求出两个整数的最大公约数。 #include int a,b; cout<<\请输入两个正整数:\ cin>>a>>b; while(a<=0 || __(1)___) {cout<<\重新输入:\ i++; } p->next=NULL; //把最后一个结点的指针域置空 p=L; L=L->next; //使L指向链表的第一个带值的结点 delete p; } (1) (2) (3) 18. 假定有定义为“struct NODE{int data; NODE* next;};”,下面算法根据table数组中的n个元素建立一个表头指针为L的链表,链表中结点值的顺序与数组元素值的顺序正好相反。 void f6(NODE*& L, int table[], int n) { L=NULL; if(n<=0) return; int i=0; NODE* p; while(___(1)___) { p=new NODE; p->data=___(2)___; p->next=L; ___(3)___; i++; } } (1) (2) (3) 19. 假定有定义为“struct NODE{int data; NODE* next;};”,下面算法是依次显示输出以L为表头指针的链表中各结点的值。 void f7(NODE* L) { for(___(1)___; p!=NULL; ___(2)___) cout<<___(3)___ <<' '; cout< (1) (2) (3) 20. 假定有定义为“struct NODE{int data; NODE* next;};”,下面算法是把以L为表头指针的链表中各结点依次按相反次序链接并返回新链表的表头指针。 NODE* f8(NODE* L) { if(L==NULL) return NULL; NODE *p=NULL, *q=L, *t; while(q!=NULL) { t=q; q=___(1)___; t->next=___(2)___; p=t; } ___(3)___; } (1) (2) (3) 21. 已知一维数组类ARRAY的定义如下,ARRAY与普通一维数组区别是:其重载的运算符[ ]要对下标是否越界进行检查。 class ARRAY{ int *v; //指向存放数组数据的空间 int s; //数组大小 public: ARRAY(int a[], int n); ~ ARRAY(){delete []v;} int size(){ return s;} int& operator[](int n); }; ___(1)___ operator[](int n) //[ ]的运算符成员函数定义 { if(n<0 || ___(2)___) {cerr<<\下标越界!\ return ___(3)___; } (1) (2) (3) 22. 已知一维数组类ARRAY的定义如下,构造函数的作用是把参数n的值赋给s,给v动态分配长度为n的数组空间,接着利用数组参数a初始化v所指向的数组。 class ARRAY{ int *v; //指向存放数组数据的空间 int s; //数组大小 public: ARRAY(int a[], int n); ~ ARRAY(){delete []v;} int size(){ return s;} int& operator[](int n); }; ___(1)___ ARRAY(int a[], int n) { if(n<=0) {v=NULL;s=0;return;} s=n; v=___(2)___; for(int i=0; i (1) (2) (3) 23. 下面是一维数组类ARRAY的定义,ARRAY与普通一维数组区别是:(a)用()而不是[]进行下标访问,(2)下标从1而不是从0开始,(c)要对下标是否越界进行检查。 class ARRAY{ int *v; //指向存放数组数据的空间 int s; //数组大小 public: ARRAY(int a[], int n); ~ ARRAY(){delete []v;} int size(){ return s;} int& operator()(int n); }; ___(1)___ operator()(int n) { // ()的运算符函数定义 if(___(2)___) {cerr<<\下标越界!\ return ___(3)___; } (1) (2) (3) 24. 已知一个类的定义如下: #include void SetA(int aa[], int nn); //用数组aa初始化数据成员a, //用nn初始化数据成员n int MaxA(); //从数组a中前n个元素中查找最大值 void SortA(); //采用选择排序的方法对数组a中前n个元素 //进行从小到大排序 void InsertA();//采用插入排序的方法对数组a中前n个元素进行从小到大排序 void PrintA(); //依次输出数组a中的前n个元素 }; 该类中MaxA()函数的实现如下,请在标号位置补充适当的内容。 int ____(1)_____ { int x=a[0]; for(int i=1; i (1) (2) (3) 25. 已知一个类的定义如下: #include class AA { int a[10]; int n; public: void SetA(int aa[], int nn); //用数组aa初始化数据成员a, //用nn初始化数据成员n int MaxA(); //从数组a中前n个元素中查找最大值 void SortA(); //采用选择排序的方法对数组a中前n个元素 //进行从小到大排序 void InsertA();//采用插入排序的方法对数组a中前n个元素进行从小到大排序 void PrintA(); //依次输出数组a中的前n个元素 }; void AA::SortA() { int i,j; for(i=0; ___(1)___; i++) { int x=a[i], k=i; for(j=i+1; j (1) (2) (3) 26. 已知一个类的定义如下: #include void SetA(int aa[], int nn); //用数组aa初始化数据成员a, //用nn初始化数据成员n int MaxA(); //从数组a中前n个元素中查找最大值 void SortA(); //采用选择排序的方法对数组a中前n个元素 //进行从小到大排序 void InsertA();//采用插入排序的方法对数组a中前n个元素进行从小到大排序 void PrintA(); //依次输出数组a中的前n个元素 }; void ___(1)___ { int i,j; for(i=1; i for(j=i-1; j>=0; j--) if(x (1) (2) (3) 27. 已知一个类的定义如下: #include void SetA(int aa[], int nn); //用数组aa初始化数据成员a, //用nn初始化数据成员n int MaxA(); //从数组a中前n个元素中查找最大值 void SortA(); //采用选择排序的方法对数组a中前n个元素 //进行从小到大排序 void InsertA();//采用插入排序的方法对数组a中前n个元素进行从小到大排序 void PrintA(); //依次输出数组a中的前n个元素 //最后输出一个换行 }; 使用该类的主函数如下: void main() { int a[10]={23,78,46,55,62,76,90,25,38,42}; AA x; ___(1)___; int m=___(2)___; ___(3)___; cout< 该程序运行结果为: 23 78 46 55 62 76 78 (1) (2) (3) 28. 已知一个类的定义如下: #include void SetA(int aa[], int nn); //用数组aa初始化数据成员a, //用nn初始化数据成员n void main() { int s0,s1,s2; s0=s1=s2=0; for(int i=0; i<8; i++) { switch(a[i]%3) { case 0: s0+=a[i];break; case 1: s1+=a[i];break; case 2: s2+=a[i];break; } } cout< 8. #include int i,p=1,s=0; for(i=1;i cout< 9. #include int c2,c3,c5; c2=c3=c5=0; for(int i=1; i<=M; i++) { if(i%2==0) c2++; if(i%3==0) c3++; if(i%5==0) c5++; } cout< 10. #include int i,j; for(i=0;i<5;i++) { for(j=i;j<5;j++) cout<<’*’; cout< } } 11. #include for(int i=1,s=0;i<20;i++) { if(i%2==0 || i%3==0) continue; cout< cout< 12. #include int i,j; for(i=1;i<=T;i+=2) for(j=2;j<=T;j+=2) { if(i+j 13. #include int a,b,c=0; for(a=1;a<4;a++) for(b=6;b>1;b-=2) { if((a+b)%2==0) c+=a+b; else c+=a*b; if(b==2) cout< 14. #include int p=1,s=1; while(s<50) { p*=B; s+=p; } cout<<\ } 15. #include int x=24,y=88; int i=2,p=1; do { while(x%i==0 && y%i==0) { p*=i; x/=i; y/=i; } i++; }while(x>=i && y>=i); cout< 16. #include int a[N][N]={{7,-5,3},{2,8,-6},{1,-4,-2}}; int b[N][N]={{3,6,-9},{2,-8,3},{5,-2,-7}}; int i,j,c[N][N]; for(i=0;i c[i][j]=a[i][j]+b[i][j]; for(i=0;i cout< 17. #include void main() { int b=a+20; int a=10; cout< for(int i=1; i<6; i++) { a+=i; b+=a; } cout< cout< 18. #include x=x+y; y=x+y; cout<<\ return x+y; } void main() { int x=5,y=8; int z=f1(x,y); cout<<\ cout<<\ } 19. #include int z=x; x=y; y=z; } void f3(int* x, int* y) { int z=*x; *x=*y; *y=z; } void main() { int x=10,y=26; cout<<\ f2(x,y); cout<<\ f3(&x,&y); cout<<\ x++; y--; f2(y,x); cout<<\ } 20. #include void f4(int a[], int n, int& s) { s=0; for(int i=0; i void main() { int b[8]={4,8,6,9,2,10,7,12}; int x; f4(b,5,x); cout< int y; f4(b+3,4,y); cout< 21. #include int a[8]={36,25,48,14,55,40,50,24}; int b1, b2; b1=b2=a[0]; for(int i=1;i<8;i++) if(a[i]>b1) {b2=b1; b1=a[i];} else if(a[i]>b2) b2=a[i]; cout< 22. #include char a[]=\ int i1=0, i2=0, i=0; while(a[i]) { if(a[i]==’a’) i1++; if(a[i]==’b’) i2++; i++; } cout< 23. #include int a[10]={76,83,54,62,40,75,90,92,77,84}; int b[4]={60,70,90,101}; int c[4]={0}; for(int i=0;i<10;i++) { int j=0; while(a[i]>=b[j]) j++; c[j]++; } for(i=0;i<4;i++) cout< 24. #include char a[5][10]={\ char s1[10], s2[10];
正在阅读:
总《面向对象程序设计c++》综合复习题集及答案详解02-27
通信工程安全操作知识手册(线路手册)05-11
江苏省江阴市五校2014-2015学年高二上学期期中考试11-02
医药代表工作总结及明年工作计划医药代表月工作计划模板04-28
墩柱施工方案06-13
我爱美丽的桂花树作文450字06-24
卷帘门施工组织设计12304-15
绍兴县东片学区九年级科学竞赛试题卷07-29
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- c++
- 习题集
- 程序设计
- 详解
- 面向
- 对象
- 答案
- 综合