东农17春《面向对象程序设计》离线作业-面向对象程序设计

[复制链接]
发表于 2017-7-3 14:28:56 | 显示全部楼层 |阅读模式
东北农业大学网络教育学院
面向对象程序设计网上作业题
第一章 C++语言概述
单项选择题:
1.下列说法中正确的是(  )。
A.a=10不是一个语句                B.常量标识符必需用大写字母表示
C.符号常量的值是可以重新赋值的     D.所有的变量在未赋初值时都有固定的值0
2.每个指令都是由二进制代码组成的只有计算机能读懂的语言是(  )。
A.机器语言     B.汇编语言     C.高级语言     D.自然语言
3.用人们比较熟悉的符号来代替指令编码的计算机语言是(  )。
A.机器语言      B.汇编语言     C.高级语言     D.自然语言
4.能够把高级语言写出的程序翻译为机器语言的指令序列的是(  )。
A.可执行程序     B.编译程序     C.解释程序    D.系统程序
5.汇编语言和机器语言都属于(  )。
A.高级语言      B.中级语言     C.低级语言     D.自然语言
6.体现结构程序设计思想的代表语言是(  )。
A.COBOL语言      B.C++语言      C.C语言      D.BASIC语言
7.体现面向对象程序设计思想的代表语言是(  )。
A.COBOL语言      B.C++语言      C.C语言      D.BASIC语言
8.用计算机解决问题的方法和步骤通常称为(  )。
A.程序       B.程序设计       C.程序设计语言      D.算法
9.C++语言程序中其右侧的所有符号都为注释的符号是(  )。
A. **      B. &&        C. ##        D. //
10.在一个C++程序中,main所代表的意义是(  )。
A.变量名称      B.主函数     C.符号常量     D.注释
11.在一个C++程序中,void main()一行中的void所代表的意义是(  )。
A.无返回值     B.主函数      C.程序开始     D.注释
12.在C++程序中,用来做为函数体开始结束标志的一对符号是(  )。
A.[]      B.{}       C.<>       D.()
13.在C++程序中,用来做为数组下标开始结束标志的一对符号是(  )。
A.[]       B.{}       C.<>       D.()
14.在C++程序中,用来做为函数参数开始结束标志的一对符号是(  )。
A.[]       B.{}       C.<>       D.()
15.C++中表示标准输入的标识符是(  )。
A.input      B.scan      C.cin      D.get
16.C++中表示标准输出的标识符是(  )。
A.output      B.print     C.put     D.cout
17.在C++的标准输出语句中使用的插入运算符是(  )。
A.<<       B.>>      C.**      D.//
18.在C++的标准输入语句中使用的提取运算符是(  )。
A.<<      B.>>      C.**      D.//
19.在C++中包含cin和cout这两个标识符说明的头文件是(  )。
A.io.h      B.stdio.h     C.iostream.h     D.inout.h
20.在C++中包含printf()和scanf()这两个函数说明的头文件是(  )。
A.io.h     B.stdio.h  C.iostream.h  D.inout.h
21.C++程序预处理命令的开始字符是(  )。(﹡*)
A.*      B./      C.&      D.#
22.下列说法正确的是(  )。
A.C++程序是从主函数开始执行的     B.C++程序中一定要定义变量
C.C++程序中一定要有输入           D.C++程序中可以从用户定义的函数开始执行
23.下列说法正确的是(  )。
A.C++程序是不是从主函数开始执行的           B.C++程序中一定要定义变量
C.C++程序中不可以从用户定义的函数开始执行   D.C++程序中一定要有用户乍定义的函数才能执行
24.下列数据类型中属于基本类型的是(  )。
A.long int       B.long float      C.unsigned int      D.void
25.下列数据类型中属于派生类型的是(  )。
A.int       B.float      C.char      D.double
26.C++程序中用来说明常量的关键字是(  )。
A.const    B.enum      C.char        D.cout
27.C++程序中用来包含头文件的关键字是(  )。
A.input     B.enum       C.include     D.cout
28.C++程序中用来说明某一变量为静态变量的关键字是(  )。
A.define       B.enum       C.extern   D.static
29.C++程序中用来说明某一变量为外部变量的关键字是(  )。
A.extern      B.enum          C.output     D.static
30.下列C++程序中变量定义的语句中,正确的是(  )。
A.int a;b;        B.int a,b;      C.a,b:int;      D.int a,b
31.下列C++程序中数组定义的语句中,正确的是(  )。
A.int a[0..10];      B.int a(10);    C.int a[10];     D.int a<10>;
32.下列程序main(){printf("%d",null);} 输出结果是(  )。
A.0   B.变量无定义    C.-1    D.1
33.以下数据中,不正确的数值或字符常量是(   )。
A.011      B.3.987E-2     C.018  D.0xabcdg
34.假设所有变量均为整型,表达式(a=2,b=5,a>b?a++:b++,a+b)的值是(   ) 。
A.7   B.8   C.9   D.2
35.在C语言中,能代表逻辑值"真"的是(       )。
A.true    B.大于0的数    C.非0整数    D.非0的数
36.以下程序
main()
{int i,j,k,a=3,b=2; i=(--a==b++)?--a:++b; j=a++;k=b; printf("i=%d,j=%d, k=%d\n",i,j,k); }
输出结果是(      )。
A.i=2,j=1,k=3      B.i=1,j=1,k=2     C.i=4,j=2,k=4      D.i=1,j=1,k=3
37.将用高级语言编写的源程序转换成目标程序的是(      )。
A.连接程序    B.汇编程序    C.编译程序     D.可执行程序
38.程序设计语言可以分为机器语言、汇编语言和(      )。
A.ALGOL语言     B.FORTRAN语言      C.C++语言        D.高级语言
39.C++对C语言作了很多改进,即从面向过程变成为面向对象的主要原因是(  )。
A.增加了一些新的运算符       B.允许函数重载,并允许设置缺省参数
C.规定函数说明符必须用原型   D.引进了类和对象的概念
40.一个C++程序至少包含的函数个数为(      )。
A.0    B.1    C.2    D.3
41.以下标识符中,不能作为合法的C++用户定义标识符的是(       )
A.For     B.Printf     C.WORD     D.sizeof
42.下列符号不能组成标识符的是(    )。
A.连接符                B.下划线   C.大小写字母      D.数字字符
43.在下列符号中,不是分隔符的是(      )。
A.[]    B.//    C.()     D.{}
44.下列标识符中,不合法的用户标识符为(      )。
A.a#b    B._int    C.a_10    D.PAd
45.由C++目标文件连接而成的可执行文件的缺省扩展名为(      )。
A.cpp       B.exe       C.obj       D.lik
46.无符号基本整型数据的取值范围是(  )。
A.-127至128       B.0至65535     C.-32768至32767      D.0至65536
47.字符型数据的取值范围是(  )。
A.-127至128      B.-32767至32768      C.-128至127  D.32768至32767
48.无符号字符型数据的取值范围是(  )。
A.0至128      B.0至256      C.0至65535     D.0至255
49.下列表示空类型的关键字是(  )。
A.char     B.void      C.space  D.include
50.用来表示水平制表的字符常量是(  )。
A.'\t'  B.'\b'  C.'\n'  D.'\f'  
51.类型修饰符unsigned不能修饰(      )。
A. char    B. int   C. long int  D. float
52.在微型机上,一个unsigned int型变量在内存中所占的字节数是(      )。
A.1    B.2    C.3    D.4
53.在微型机上,一个char型变量在内存中所占的字节数是(     )。
A.1    B.2    C.3    D.4
54.在微型机上,一个float型变量在内存中所占的字节数是(      )。
A.1    B.2    C.3    D.4
55.在定义变量时省略存储类的说明,则系统按哪个存储类处理(  )。
A.auto  B.register  C.static  D.extern
56.下列语句中是常量定义的语句是(  )。
A.#define PI 3.14159265   B.double a=3.14159265;   C.const PI=3.14159265;    D.a=3.14159265;
57.下列数据属于八进制整型常量的是(  )。
A.01.2      B.123     C.0123     D.X123
58.下列数据属于十六进制整型常量的是(  )。
A.01.2     B.123      C.0123     D.0X123
59.下面不正确的字符串常量是(      )。
A.'abc' B."12'12"  C."0"    D." "
60.设有整型变量x和指针变量p,已知p的值为a的地址,则表达式*p==a的值是(  )
A.0  B.1  C.2  D.3
61.设有整型变量x和指针变量p,则要使指针p指向变量a的表达式是(  )
A.p=&a  B.p=&a;  C.*p=a  D.*a=p
62.下列运算符中表示逻辑非运算的是(  )
A.&  B.|  C.!  D.*
63.下列运算符中表示逻辑与运算的是(  )
A.&&  B.||  C.!!  D.**
64.下列运算符中表示逻辑或运算的是(  )
A.&&  B.||  C.!!  D.**
65.下列运算符中是关系运算符的是(  )
A.&&  B.||  C.!!  D.==
66.下列运算符中是算术运算符的是(  )
A.&&  B.++  C.!!  D.==
67.下列运算符中表示释放指针所指内存单元的是(  )
A.sizeof  B.new  C.delete  D.break;
68.下列运算符中表示为某指针申请内存单元的是(  )
A.sizeof  B.new  C.delete  D.break;
69.下列运算符中功能为字长提取符的是(  )
A.sizeof  B.new  C.delete  D.break;
70.为表示关系x>=y>=z,应使用C语言表达式(       )
A.(x>=y)&&(y>=z)      B.(x>=y)AND(y>=z)    C.(x>=y>=z)           D.(x>=y)&(y>=z)
71.若要求在if后一对圆括号中表示a不等于0的关系, 则能正确表示这一关系的表达式为(       )
A.a<>0    B.! a    C.a=0    D.a
72.C++语言中最简单的数据类型包括(     )
A.整型、实型、逻辑型       B.整型、实型、字符型
C.整型、字符型、逻辑型     D.整型、实型、逻辑型、字符型
73.C++语言中,运作对象必须是整型数的运算符是(     )
A.%     B.\     C)%和\      D.* *
74.设a=12,n=5,则表达式a%=(n%=2)运算后,a的值为(      )。
A.0    B.1    C.6    D.12
75.条件运算符是(  )
A.?:    B.:?    C./:   D.:/
76.地址运算符是(  )
A.*    B.:    C.&   D.#
77.设a=3,b=2,c=l,则表达式a=b>c的值为(      )。
A.0    B.1    C.2    D.3
78.以下程序段 int a=10; printf("%d\n",-a,); 输出结果是(       )
A.01    B.-11    C.-10    D.-5
79.当a=1,b=2,c=3时,执行以下if语句a,b,c各为(      )。
if(a>c);b=a;a=c;c=b;
A.a=1 b=2 c=3    B.a=2 b=3 c=1    C.a=3 b=1 c=1    D.a=3 b=1 c=2
80.下面关于条件语句的叙述中,错误的是(      )。
A.if语句只有一个else语句            B.if语句中可以有多个else if语句
C.if语句中if体内不能是switch语句   D.if语句的if体中可以是循环语句
81.以下程序段的输出结果是(       ) int x=3; do { printf("%3d",x-=2); } while(!(--x));           
A.1      B.30     C.1 -2     D.死循环
82.下述语句
int k=10;
while(k=0)k=k-1;
则下面描述正确的是(      )。
A.while循环执行10次         B.循环是无限循环
C.循环体语句一次也不执行     D.循环体语句执行一次
83.语句while(!E);中的表达式!E等价于(      )。
A.E==0    B.E!=1    C.E!=0    D.E==1
84.在C++语言程序中跳出循环结构的语句是(  )。
A.continue;  B.break;  C.return;  D.goto;
85.在C++语言程序的继续语句是(  )
A.continue;  B.break;  C.return;  D.goto;
86.在C++语言程序的返回语句是(  )
A.continue;  B.break;  C.return;  D.goto;
87.在C++语言程序的转向语句是(  )
A.continue;  B.break;  C.return;  D.goto;
88.设有数组定义语句int a[10];则a[5]是数组中的第几个元素(  )
A.3  B.4  C.5  D.6
89.设有数组定义语句int a[10];则a[1]是数组中的第几个元素(  )
A.1  B.2  C.3  D.4
90.设有数组定义语句int a[2][2];则a[1][1]是数组中的第几个元素(  )
A.1  B.2  C.3  D.4
91.设有数组定义语句int a[2][2],p=2;则为数组a第3个元素赋值为5的语句是(  )
A.a[p-1][0]=p;  B.a[1][p-2]=p+3;   C.a[3]=5;       D.a[p+1]=p+3;
92.下面程序 int aa[3][3]={2},{4},{6}}; main() { int i,* p=&aa[0][0]; for(i=0;i<2;i++) {if(i==0) aa[i][i+1]= * p+1; else ++p; printf("%d",* p+1);} } 输出结果是(       )  
A.23     B.26     C.33     D.36
93.在下面的一维数组定义中,有语法错误的是(      )。
A.int a[]={1,2,3}; B.int a[10]={0};  C.int a[]; D.int a[5];
94.在下面的函数声明中,存在着语法错误的是(      )。
A.void BC(int a, int);          B.void BD(int, int);
C.void BE(int, int=5);          D.int BF(int x; int y);
95.C++语言程序中,当调用函数时(    )
A.实参和虚参各占一个独立的存储单元     B.实参和虚参可以共用存储单元
C.可以由用户指定是否共用存储单元       D.由计算机系统自动确定是否共用存储单元
96.在int a=3,int *p=&a;中,*p的值是(    )。
A.变量a的地址值        B.无意义  C.变量p的地址值  D.3
97.C++语言程序中取某地址中的值的运算符是(    )。
A.#  B.&  C.*  D.%
98.C++语言程序中取某变量地址的运算符是(  )
A.#  B.&  C.*  D.%
99.已知函数fread的调用形式为fread(buffer, size, count, fp), 其中buffer代表的是(   )
A.存放读入数据项的存储区                   B.一个指向所读文件的文件指针
C.存放读入数据的地址或指向此地址的指针     D.一个整型变量,代表要读入的数据项总数
100.下列(    )的调用方式是引用调用。
A. 形参和实参都是变量                          B.形参是指针,实参是地址值
C. 形参是引用,实参是变量                      D.形参是变量,实参是地址值
101.C++源程序文件的缺省扩展名为(    )。
A. cpp              B. exe                C. obj                 D. lik
102.由C++源程序文件编译而成的目标文件的缺省扩展名为(    )。
A. cpp                  B. exe                C. obj                 D. lik
103.由C++目标文件连接而成的可执行文件的缺省扩展名为(    )。
A. cpp            B. exe                C. obj                 D. lik
104.编写C++程序一般需经过的几个步骤依次是(      )。
A. 编译、编辑、连接、调试             B. 编辑、编译、连接、调试
C. 编译、调试、编辑、连接             D. 编辑、调试、编辑、连接
105.以下标识符中不全是保留字的是(    )。
A. case    for    int               B. default  then   while
C. bool    class   long             D. goto   return  char
106.能作为C++程序的基本单位是(    )。
A. 字符            B. 语句                C. 函数     D. 源程序文件
107.程序中主函数的名字为(    )。
A. main            B. MAIN                C. Main   D. 任意标识符
108.C++程序的基本模块为(    )。
A. 表达式           B. 标识符                C. 语句          D. 函数
109.可用作C++语言用户标识符的一组标识符是(    )。
A. void    define    +WORD        B. a3_b3    _123     YN
C. for      -abc      Case          D. 2a      DO      sizeof
110.存储以下数据,占用存储字节最多的是(    )。
A. 0            B. ‘0’        C. “0”             D. 0.0
111.程序运行中需要从键盘上输入多于一个数据时,各数据之间应使用(    )符号作为分隔符。
A. 空格或逗号            B. 逗号或回车                C. 逗号或分号          D. 空格或回车
112.设”int a=12;”,则执行完语句”a+=a*a;”后,a的值是(    )。
A. 12                      B. 144                        C. 156                    D. 288
113.假设在程序中 a、b、c 均被定义成整型,所赋的值都大于1,则下列能正确表示代数式的表达式是(    )。   
A. 1.0/a*b*c            B. 1/(a*b*c)      C. 1/a/b/(float)c    D. 1.0/a/b/c
114.设”int a=15,b=26;”,则”cout<<(a,b);”的输出结果是(    )。
A. 15            B. 26,15        C. 15,26             D. 26
115.设x是一个bool型的逻辑量,y的值为10,则表达式 x && y的值为(    )。
A. 1              B. 0        C. 与x值相同             D. 与x值相反
116.x>0 && x<=10的相反表达式为(    )。
A. x<=0 || x>10            B. x<=0 && x>10     C. x<=0 || x<=10             D. x>0 && x>10
117.x>0 || y==5的相反表达式为(    )。
A. x<=0 || y!=5           B. x<=0 && y!=5     C. x>0 || y!=5            D. x>0 && y==5
118.设x和y均为bool量,则x && y为真的条件是(    )。
A. 它们均为真           B. 其中一个为真   C. 它们均为假           D. 其中一个为假
119.设x和y均为bool量,则x || y为假的条件是(    )。
A. 它们均为真           B. 其中一个为真   C. 它们均为假     D. 其中一个为假
120.字符串”a+b=12\n”的长度为(    )。
A. 6           B. 7     C. 8            D. 9
121.假定下列x和y均为int型变量,则不正确的赋值为(    )。
A. x+=y++           B. x++=y++    C. x=++y             D. ++x=++y
122.下列的符号常量定义中,错误的定义是(    )。
A. const M=10;                                 B. const int M=20;
C. const char ch;                              D. const bool mark=true;
123.循环语句“for(int i=0; i<n; i++) cout<<i*i<<’ ’;”中循环体执行的次数为(    )。
A. 1            B. n-1      C. n             D. n+1
124.在下面循环语句中循环体执行的次数为(    )。
for(int i=0; i<n; i++)
if(i>n/2) break;
A. n/2           B. n/2+1     C. n/2-1             D. n-1
125.在下面循环语句中内层循环体S语句的执行总次数为(    )。
for(int i=0; i<n; i++)
for(int j=i; j<n; j++) S;
A. n2              B. (n+1)/2     C. n(n-1)/2             D. n(n+1)/2
126.在下面循环语句中循环体执行的次数为(    )。
int i=0,s=0; while(s<20) {i++; s+=i;}
A. 4            B. 5     C. 6            D. 7
127.在下面循环语句中循环体执行的次数为(    )。
int i=0; do i++; while(i*i<10);
A. 4            B. 3    C. 5              D. 2
128.当处理特定问题时的循环次数已知时,通常采用(    )来解决。
A. for循环            B. while循环    C. do循环           D. switch语句
129.循环体至少被执行一次的语句为(    )。
A. for循环           B. while循环    C. do循环            D. 任一种循环
130.switch语句能够改写为(    )语句。
A. for          B. if     C. do             D. while
131.do语句能够改写为(    )语句。
A. 复合                    B. if     C. switch             D. while
132.. 在下面的一维数组定义中,哪一个有语法错误。(    )
A. int a[]={1,2,3};            B. int a[10]={0};    C. int a[];           D. int a[5];
133.在下面的字符数组定义中,哪一个有语法错误。(    )。
A. char a[20]=”abcdefg”;              B. char a[]=”x+y=55.”;
C. char a[15];                                D. char a[10]=’5’;
134.在下面的二维数组定义中,正确的是(    )。
A. int a[5][];          B. int a[][5];    C. int a[][3]={{1,3,5},{2}};            D. int a[](10);
135.假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[1][2]的值为(    )。
A. 2              B. 4       C. 6              D. 8
136.假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[2][1]的值为(    )。
A. 0              B. 4     C. 8              D. 6
137.若定义了函数 double *function(), 则函数function的返回值为(    )。
A. 实数型            B.实数的地址    C.指向函数的指针            D.函数的地址
138.以下说法中正确的是(    )。
A. C++程序总是从第一个定义的函数开始执行
B. C++程序总是从main函数开始执行
C. C++函数必须有返回值,否则不能使用函数
D. C++程序中有调用关系的所有函数必须放在同一个程序文件中
139.以下叙述中不正确的是(    )。
A. 在一个函数中,可以有多条return语句
B. 函数的定义不能嵌套,但函数的调用可以嵌套
C. 函数必须有返回值
D. 不同的函数中可以使用相同名字的变量
140.函数重载是指(    )。
A. 两个或两个以上的函数取相同的函数名,但形参的个数或类型不同
B. 两个以上的函数取相同的名字和具有相同的参数个数,但形参的类型可以不同
C. 两个以上的函数名字不同,但形参的个数或类型相同
D. 两个以上的函数取相同的函数名,并且函数的返回类型相同
141.C++语言的编译系统对宏命令的处理是(    )。
A. 在程序运行时进行                    B. 在程序连接时进行
C. 和C++程序的其它语句同时进行编译   D. 在对源程序中其它成分正式编译之前进行
142.当#include后面的文件名用双引号括起来时,寻找被包含文件的方式是(    )。
A. 直接按系统设定的标准方式搜索目录
B. 先在源程序所在目录搜索,再按系统设定的标准方式搜索目录
C. 仅仅搜索源程序所在目录
D. 搜索当前逻辑盘上的所有目录
143.为了提高程序的运行速度,可将不太复杂的功能用函数实现,此函数应选择(    )。
A. 内联函数                  B.重载函数             C.递归函数                  D.函数模板
144.函数原型语句正确的是(    )。
A. int Function(void a);          B.void Function (int);   C. int Function(a);          D.void int(double a);
145.C++中函数返回值的类型是由(    )决定的。
A. return语句中表达式的类型                   B.该函数定义时的类型
C.调用函数时的调用语句                         D.系统根据结果
146.以下函数的返回结果是(    )。
int function(char *x) {
char *p=x; while(*p++); return(p-x-1);
}
A. 求字符串的长度                       B.将字符串x连接到字符串p后面
C. 将字符串x复制到字符串p中           D.将字符串x反向存放
147.函数调用func((exp1,exp2),(exp3,exp4,exp5))中所含实参的个数为(    )个。
A.  1             B.  2     C.  4             D.  5
148.设有如下函数定义
int f(char *s) {
char *p=s;
while(*p!=’\0’) p++;
return(p-s);
}
在主函数中用cout<<f(“good”)调用上述函数, 则输出结果为(    )。
A. 3           B. 4      C. 5            D. 6
149.以下正确的函数原型语句是(    )。
A. double fun(int x,int y)                    B. double fun(int x;int y)
C. double fun(int,int);                            D. double fun(int x,y);
150.以下正确的说法是(    )。
A. 用户调用标准库函数前,必须重新定义
B. 用户可以重新定义标准库函数,若如此,该函数将失去原有含义
C. 系统不允许用户重新定义标准库函数
D. 用户调用标准库函数前,不必使用预编译命令将该函数所在文件包括到用户源文件中
151.函数调用不可以(    )。
A. 出现在一个表达式中          B. 出现在执行语句中 C. 作为一个函数的实参  D. 作为一个函数的形参
152.以下正确的描述是(    )。
A. 函数的定义可以嵌套,函数的调用不可以嵌套
B. 函数的定义不可以嵌套,函数的调用可以嵌套
C. 函数的定义和函数的调用均可以嵌套
D. 函数的定义和函数的调用均不可以嵌套
153.若用数组名作为函数调用的实参,传递给形参的是(    )。
A. 数组的首地址                                        B. 数组中第一个元素的值
C. 数组全部元素的值                                    D. 数组元素的个数
154.以下错误的描述是(    )。
A. 被调用函数中可以不用return语句
B. 被调用函数中可以用多个return语句
C. 被调用函数中,如果有返回值,就一定要有return语句
D. 被调用函数中,一个return语句可返回多个值给调用函数
155.以下正确的描述是(    )。
A. 不允许设置参数的默认值
B. 设置参数的默认值只能在定义函数时设置
C. 设置参数的默认值时,应该设置右边的参数
D. 设置参数的默认值时,应该全部参数都设置
156.采用重载函数的目的是(    )。
A. 实现共享           B. 减少空间   C. 提高速度   D. 使用方便,提高可读性
157.将两个字符串连接起来组成一个字符串时,选用(    )函数。
A. strlen()           B. strcap()    C. strcat()            D. strcmp()
158.以下叙述中正确的是(    )。
A. 使用#define可以为常量定义一个名字,该名字在程序中可以再赋另外的值
B. 使用const定义的常量名有类型之分,其值在程序运行时是不可改变的
C. 在程序中使用内联函数使程序的可读性变差
D. 在定义函数时可以在形参表的任何位置给出缺省形参值
159.下面的标识符中,(    )是文件级作用域。
A. 函数形参          B.语句标号    C.外部静态类标识符          D.自动类标识符
160.以下叙述不正确的是(    )。
A. 宏替换不占用运行时间                    B. 宏名无类型
C. 宏替换只是字符替换                      D. 宏名必须用大写字母表示
161.下列对引用的陈述中不正确的是(   )。
A. 每一个引用都是其所引用对象的别名,因此必须初始化
B. 形式上针对引用的操作实际上作用于它所引用的对象
C. 一旦定义了引用,一切针对其所引用对象的操作只能通过该引用间接进行
D. 不需要单独为引用分配存储空间
162.假定变量a和pa定义为“double a[10], *pa=a;”,要将12.35赋值给a中的下标为5的元素,不正确的语句是(    )。
A. pa[5]=12.35;          B. a[5]=12.35;    C. *(pa+5)=12.35;          D. *(a[0]+5)=12.35;
163.假定变量b和pb定义为“int b[10], *pb=b;”,要将24赋值给b[1]元素中,不正确的语句是(    )。
A. *(pb+1)=24;           B. *(b+1)=24;    C. *++b=24;           D. *++pb=24;
164.假定指针变量p定义为“int *p=new int(100);”,要释放p所指向的动态内存,应使用语句(    )。
A. delete p;            B. delete *p;      C. delete &p;           D. delete []p;
165.假定指针变量p定义为“int *p=new int[30];”,要释放p所指向的动态内存,应使用语句(    )。
A. delete p;           B. delete *p;     C. delete &p;             D. delete []p;
166.关于局部变量,下面说法正确的是(    )。
A. 定义该变量的程序文件中的函数都可以访问
B. 定义该变量的函数中的定义处以下的任何语句都可以访问
C. 定义该变量的复合语句中的定义处以下的任何语句都可以访问
D. 定义该变量的函数中的定义处以上的任何语句都可以访问
167.文件包含命令中被包含的文件的扩展名(    )。
A. 必须是.h            B. 不能是.h    C. 可以是.h或.cpp           D. 必须是.cpp
168.预处理命令在程序中都是以(    )符号开头的。
A. *             B. #      C. &             D. @
169.设array为一个数组,则表达式sizeof(array)/sizeof(array[0])的结果为(    )。
A. array数组首地址                       B. array数组中元素个数
C. array数组中每个元素所占的字节数       D. array数组占的总字节数
170.用new运算符创建一个含10个元素的一维整型数组的正确语句是(    )。
A. int *p=new a[10];                              B. int *p=new float[10];
C. int *p=new int[10];                            D. int *p=new int[10]={1,2,3,4,5}
171.下列给字符数组赋初值时,正确的是(    )。
A. char s1[]=”abcdef”;                   B. char s2[4]=”abcd”;
C. char s3[2][3]={“abc”,”xyz”};        D. char s4[4][]={‘a’,’x’,’s’,’t’};
172.设有定义“static int data[5][6];”,设该数组在静态存储区中的起始地址为十进制的100,若每个int型数占4个字节,则数组元素data[2][3]的地址为(    )。
A. 115            B.124     C.130             D.160
173.假定变量m定义为“int m=7;”,则定义变量p的正确语句为(   )。
A.  int p=&m;    B.  int *p=&m;    C.  int &p=*m;     D.  int *p=m;
174.. 假定k是一个double类型的变量,则关于变量p的正确定义语句为(   )。
A. double p=&k;                                 B. int *p=&k;
C. double &p=*k;                                D. char *p=”Thank you!”;
175.变量s的定义为“char *s=”Hello world!”;”,要使变量p指向s所指向的同一个字符串,则应选取(   )。
A. char *p=s;            B. char *p=&s;     C. char *p;p=*s;          D. char *p; p=&s;
176.关于void 指针,下列说法正确的是(   )。
A. void 指针就是未指向任何数据的指针
B. void 指针就是已定义而未初始化的指针
C. 指向任何类型数据的指针可直接赋值给一个void 指针
D. void 指针值可直接赋给一个非void 指针
177.假定一条定义语句为“int a[10], x, *pa=a;”,若要把数组a中下标为3的元素值赋给x,则不正确的语句为(   )。
A. x=pa[3];           B. x=*(a+3);     C. x=a[3];   D. x=*pa+3;
178.假定有定义“int b[10]; int *pb;”,则不正确的赋值语句为(   )。
A. pb=b;           B. pb=&b[0];     C. *pb=new int;           D. pb=b[5];
179.假定p是具有double类型的指针变量,则表达式++p使p的值(以字节为单位)增加(   )。
A. 1            B. 4      C. sizeof(double)          D. sizeof(p)
180.假定p指向的字符串为”string”,则cout<<p+3的输出结果为(    )。
A. string            B. ring     C. ing            D. i
181.假定p指向的字符串为”string”,若要输出这个字符串的地址值,则使用(    )。
A. cout<<*s;        B. cout<<s;     C. cout<<&s;          D. cout<<(void *)s;
182.定义p并使p指向动态空间中的包含30个整数的数组所使用的定义语句为(   )。
A. int *p=new int[30];                        B. int *p=new int(30);
C. int *p=new [30];                           D. *p=new int[30];
183.假定p是具有int**类型的指针变量,则给p赋值的正确语句为(    )。
A. p=new int;           B. p=new int*;     C. p=new int**;   D. p=new int[10];
184.要使语句“p=new int[10][20];”能够正常执行,p应被事先定义为(   )。
A. int *p;           B. int **p;     C. int *p[20];    D. int(*p)[20];
185.假定有“struct BOOK{char title[40]; float price;}; BOOK *book=new BOOK;”,则正确的语句为(   )。
A. strcpy(book->title,”Wang Tao”);     B. strcpy(book.title,”Wang Tao”);
C. strcpy(*book.title,”Wang Tao”);     D. strcpy((*book)->title,”Wang Tao”);
186.假定有“struct BOOK{char title[40]; float price;}; BOOK *book;”,则不正确的语句为(   )。
A. BOOK *x=new book;                               B. BOOK x={"C++ Programming",27.0};
C. BOOK *x=new BOOK;                       D.  BOOK *x=book;
187.假定有“struct BOOK{char title[40]; float price;}book;”,则正确的语句为(   )。
A. BOOK &x= &book;                                 B. BOOK &x=book;
C. BOOK &x=new BOOK;                       D. BOOK &x=BOOK;
188.假定变量x定义为“int x=5;”,要使rx成为x的引用(别名),rx应定义为(   )。
A. int rx=x;           B. int rx=&x;     C. int *rx=&x;          D. int &rx=x;


填空题:
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(    );”可知,该函数的返回类型为(    ),该函数带有( )个参数。
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,则x%y和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.?数学算式?的C++表达式为( (x+y)/(     )。
50.?数学算式?的C++表达式为( 3*x*y/(      )。
51.?数学算式?的C++表达式为( 1/(      )。
52.?设enum?Printstatus{ready,busy,error};?则?cout<<busy的输出结果是(  )。
53.?设enum?Printstatus{ready=2,busy,error};?则cout<<busy的输出结果是(  )。
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.?若需要把一个字符串”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.C++中约定源文件使用扩展名 (*.cpp),头文件使用扩展名  (     ) 。
92.C++中标准的输入输出流是 (    ) 和 (    ),它们是在 (  ) 头文件中定义。
93.C++既是面向 (    ) ,又是面向 (     ) 。
94.在C++中有两种类型的注释符,一种是C语言中使用的注释符(     ),另一种是( )。
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]的类型为( int[n] ),访问a[i]时返回值的类型为(     )。
129.?假定一个二维数组为c[5][8],则c[3]的值为二维元素( c[3][0] )的地址,c[3]+2的值为二维元素(     )的地址。
130.?假定p为指向二维数组int?d[4][6]的指针,则p的类型为(      )。
131.?假定a是一个二维数组,则a[i][j]的指针访问方式为( *(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(     )操作后,p所指向的数据对象的值为(     )。
138.?执行new?char[m][n]操作时的返回值的类型为(    )。
139.?执行(     )操作将释放由p所指向的动态分配的数据空间。
140.?执行(      )操作将释放由p所指向的动态分配的数组空间。
141.?NULL是一个符号常量,通常作为空指针值,它的具体值为(      )。
142.?变量v定义为“double?v=23.4;”,要使指针pv指向v,则定义pv的语句为(       )。
143.?已知语句“cout<<p;”的输出是“Hello!”,则语句“cout<<*p;”输出的是(     )。
144.?已知语句“cout<<s;”的输出是“apple”,则执行语句“cout<<s+2;”的输出结果为( ple )。
145.?指针变量pv和pc定义为“void?*pv?=”Hello,?word!”;?char?*pc;”,要将pv值赋给pc,则正确的赋值语句是(         )。
146.?数组a定义为“int?a[100];”,要使p[j]?与a[j]?等效,则指针p应定义为( int (*p)[100]=b; )。int?*p=a;??(         )
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的值是(  )。

程序填空题:
1.下列递归函数计算(1+2+3+…+n), 请填空完成程序。
int sum(int n)  
{
  ____(1)____ m;
  if(n<1) ____(2)____;
  else m=n + sum(n-1);
  return ____(3)____;
}

2.输入N个整数,输出其中最大数。
void main()
{
  const int N=100;         
  int max, a[N], j;
  for(j=0; j<N; j++)
    cin>>____(1)____;
  max=a[0];
  for(j=1; j<N; j++)
    if(a[j]>max) max=a[j];
  cout <<____(2)____;
}

3.请填空完成下列递归计算 的函数。
int fac(int n, int m)
{
  int p;
  if(m<1) ____(1)____;
  else p=n*fac(n,____(2)____);
  return ____(3)____;
}

4.下面是求一个5*5矩阵对角线元素和的程序, 请填空完成程序。
#include <iostream.h>           
void main()
{
  const int N=5;
  int i,j;
  double sum=0.0, a[N][N];
  for(i=0;i<N;i++)
    for(j=0;j<N;j++)
       cin>>a[i][j];
  for(i=0;i<____(1)____;i++)
     sum+=____(2)____;
  cout <<sum<<endl;
}

5.下面程序将键盘输入的一个三位整数,倒序输出到屏幕(例如,输入的是125,输出的是521), 请填空完成该程序。
#include <iostream.h>
void main()
{
        int n,a=0,b=0,c=0;
        cin>>n;
        if(____(1)____)
        {
                a=____(2)____;
                b=n/10%10;
                c=____(3)____;   
                cout<<a<<b<<c<<endl;
        }
        else
                cout<<"input error!"<<endl;
}

6.一个函数将一个数组中的值按逆序重现存放,填空完成该函数。
void inverse(int ____(1)____,int n)
{
        int j,k,t;
        j=0;k=____(2)____;
        while(j<k)
        {
                t=a[j];a[j]=a[k];a[k]=t;
                j++;k--;
        }
}

7.下面的函数计算一字符串的长度,请填空完成改函数。
int strlength(char ____(1)____)
{
  int k=0;
  while (s[k]!=____(2)____)
    k++;
  return ____(3)____;
}

8.下面的函数将一个字符串接到另一个字符串后面,请填空完成该程序。
void strcat(char s1[ ], char s2[ ])
{
  int k=0,j=0;
  while (s1[k]!='\0')
    ____(1)____;
  while (s2[j]!='\0')
  {
    s1[k]=____(2)____;
    k++; j++;
  }
}

9.下面的程序计算下列级数的和:
  s=1/1+1/2+1/3+...+1/n
  请填空完成该程序。
#include <____(1)____>           
void main()
{
  int i, N;        
  double f, sum=0;
  cin>>N;
  for(____(2)____;i<=N ;i++)
  {
     f= 1.0/ (double)i;
     sum+=____(3)____;
  }
  cout <<sum<<endl;
}

10.下列程序验证100以内奇整数,其平方被8整除余一,请填空完成该程序。
#include <iostream.h>
void main()
{
  int m, n;
  for(____(1)____; m<100; m+=2)
  {
    n=____(2)____;
    if(n%8!=1) break;
  }
  if(m>=100)
    cout <<" 奇数的平方被8整除余1是正确的"<<endl;            
  else
    cout <<" 奇数的平方被8整除余1是错误的"<<endl;
}   


11.下列程序是完成由公制转换到英制尺寸的程序(已知一英尺为25.4cm),请填空完成该程序。
#include <____(1)____>
void main()
{
  float inch, cm,;
  cout<<"Enter the height:";
  cin>>____(2)____;
  inch=cm*____(3)____;
  cout<<endl<<"The height is:";
  cout<<cm<<"cm="<<inch<<"inch\n";
}   


12.下列程序是求表达式
100                50                10
∑ K +        ∑ K2 +∑ 1/K
K=1                K=1                K=1
                的值,请填空完成该程序。
#include <iostream.h>
void main()
{
        int K;
        double sum=0.0, sk1=0.0, sk2=0.0, sk3=0.0;
        for(K=1;K<=100;K++)
        {
                sk1+=K;
        }
        for(K=1;K<=50;K++)
        {
                sk2+=____(1)____;
        }
        for(K=1;K<=10;K++)
        {
                sk3+=1/double(K);
        }
        sum=____(2)____;
    cout << "表达式值为: " << sum <<endl;
}

13.下面程序求满足以下条件的最大的n:
        1*1 + 2*2 + 3*3 +…+ n*n < 1000
                请填空完成该程序。
#include <iostream.h>
void main()
{
        int n=1;
        int sum=1*1;
        while(____(1)____)
        {
                n++;
                sum+=____(2)____;
        }
        ____(3)____;
        cout << "满足条件的 n ="<<n<<endl;
}


14.按给定的半径r计算圆的面积a和周长c。下面的程序用键盘输入r的值,计算a、c并输出到屏幕。请填空完成该程序。
#include <iostream.h>
void computeCircle(double& a, double& c, double r)
{
        const double PI=3.1415926;
        a=____(1)____;
        c=2*PI*r;
}
void main()
{
        double r,a,c;
                cin>>r;
        ____(2)____(a, c, r);
    cout << "面积="<< a << endl;
    cout << "周长="<< c << endl;
}


15.有一个数列,它的第一项为0,第二项为1,以后每一项都是它的前两项之和。下面的程序产生此数列的前20项,并按逆序显示出来。请填空完成该程序。
#include <iostream.h>
void main()
{
        int a[20];
        a[0]=0, a[1]=1;
        int i;
        for(____(1)____;i<20;i++)
        {
                a[i]=____(2)____;
        }
        for(i=____(3)____;i>=0;i--)
      cout<<a[i]<<" "<<endl;
}

16.下面的程用键盘输入三个数,并向屏幕输出最大者(要求用条件表达式)。请填空完成该程序。
#include <iostream.h>
void main()
{
  float a,b,c,max=0.0;
  cin>>a>>b>>c;
  if(a>=b)  max=a;
  else      ____(1)____;
  if(c>=max) max=c;
     cout<< ____(2)____<<endl;
}

17.下面的程序把100至200之间的能被7整除的数输出到屏幕。请填空完成该程序。
#include <iostream.h>
void main()
{
  int n;
  for(____(1)____;n<=200; n++)
  {
    if(n%7!=0)
      ____(2)____;        
    ____(3)____<<n<<" ;";
  }
}

18.下面的程序从键盘输入一个字符,判别它是否为大写字母,若是将它转换成小写字母,若不是,不转换。请填空完成该程序。
#include <iostream.h>                  
void main()
{
  char ch;
  cin>>____(1)____;
  ch=(ch>='A'&&ch<='Z')  ____(2)____  (ch+32):ch;
  cout<< ch << endl;
}

19.下面的程序计算下列级数的和:         
   e=1/1! + 1/2! + 1/3! + ... + 1/n!
是自然对数的底,当最后一项近似值小于10E-7,循环结束,请填空完成该程序。
#include <iostream.h>
void main()
{
  const double eps=1e-7;         
  int n=1;
  ____(1)____ e=1.0, r=1.0;
  do
  {
    e+=r;
    n++;
    r/=____(2)____;
  }____(3)____(r>eps);
  cout<<" The Value is";
  cout <<e<<endl;
}

20.下面的函数统计字符串中,某字符出现的频率,请填空完成该程序。
int total(char s[ ],char c)
{
  int n,k;
  k=0;
  while(s[____(1)____]!='\0')
     if(s[k++]==c)  n++;
  return ____(2)____;
}

21.编写一个函数,返回2个参数(整数)中的小者,请填空完成该程序。
int min(int a, ____(1)____)
{
   if (____(2)____)
                   return a;
   else
                ____(3)____;
}


22.将一数组的数据倒着输出,请填空完成该程序。
#include<iostream.h>
void main()
{
  int a[]={9,8,7,6,5,4,3,2,1};
  int i=8;
  do
  {
     cout<<____(1)____<<endl;
     i--;
  }
  ____(2)____(i>=0);
}

23.编程输出1-100之间的素数,请填空完成该程序。
#include <iostream.h>
#include <____(1)____>               
void main()
{
  ____(2)____;                  
  for(m=1; m<=100; m+=2)
  {
    tag=1;
    k=sqrt(m);                    
    for(i=2;i<k;i++)
      if(m%i==0)
      {
        tag=0;
        break;  
      }
    if (tag= =1)         
        cout <<____(3)____<<endl;            
  }
}

24.下列程序段应输出100以内的奇数,请填空完成该程序。
#include<iostream.h>
____(1)____
{
  int k;
  for(k=1; k<100; k++)
  if (k%2== ____(2)____)
     cout<<k<<',';
}

25.计算输出20!的结果,请填空完成该程序。
#include<iostream.h>
____(1)____
{
  int i;
  ____(2)____;
  for(i=1;i<=20;i++)
     sum*=____(3)____;
  cout<<"sum="<< sum <<endl;
}

26.下列程序段应输出20以内的偶数,请填空完成该程序。
#include<iostream.h>
void main()
{
    int ____(1)____;
        for(k=2; k<20; k++)
                        if(____(2)____)  cout<<k<<',';
}

27.下列程序的功能是将字符串s中的所有空格进行压缩删除,然后输出,请填空完成程序。
#include <iostream.h>
void main()
{
        char s[]="We are learning C++ language";
        for(int i=0, j=0; s[i]!='\0'; i++)
                if(____(1)____)  s[j++]=s[i];
        ____(2)____;
        cout << ____(3)____ << endl;
}

28.下面程序是从键盘输入学号,然后输出学号中的百分数字是3的学号,输入0时结束循环。请填空完成程序。
#include <iostream.h>
void main()
{
        int num;
        cin>> num;
        do
        {
                if(____(1)____)  
                        cout<< num <<endl;
                cin>> num;
        }while(____(2)____);
}


29.以下是一个采用类结构的方式求n!的程序,请填空完成程序。
#include <iostream.h>
class Factorial
{
        int n;        int fact;
public:
        Factorial(int val){                n=val;____(1)____;}
        void Calculate(){ int i=n;  while(i>1) ____(2)____;}
        void Display(){        cout<<n<<"!="<<fact<<endl;}
};
void main()
{
        int n;
        cin>>n;
        ____(3)____;
        A.Calculate();
        A.Display();
}

30.下列程序是用递归的方法计算fun(5)*10的值。其中fun(k)=fun(k-1)*k, 当k=0时,fun(0)=3。运行结果为3600,请填空完成程序。
#include <iostream.h>
int fun(int k)
{
        if(k==0)
                ____(1)____;
        return fun(k-1)*k;
}

void main()
{
        ____(2)____;
        cout << fun(n)*10<<endl;
}


31.?斐波那契数列的第1和第2个数分别为0和1?,从第三个数开始,每个数等于其前两个数之和。求斐波那契数列中的前20个数,要求每行输出5个数。
#include<iostream.h>
void?main()?{
????int?f,f1,f2,i;
????cout<<”?斐波那契数列:\n”;
????f1=0;?f2=1;
????cout<<setw(6)<<f1<<setw(6)<<f2;
????for(i=3;i<=20;i++)?{
????????f=______(1)______;?
cout<<setw(6)<<f;
if(_____(2)______)?cout<<endl;
f1=f2;
f2=____(3)_______;
????????}
????????cout<<endl;
????}

32.?计算?的值。
????????#include<iostream.h>
????????void?main()
????????{
????????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)____;
????????s+=j*p1/p2;??//j的值为(-1)i+1
????????j=____(3)____;
????????}
????????cout<<s<<endl;
????????}


33.?打印出2至99之间的所有素数(即不能被任何数整除的数)。
????????#include<iostream.h>
????????#include<math.h>
????????void?main()
????????{
????????????int?i,n;
????????for(n=2;?___(1)___;?n++)?{
????????int?temp=int(sqrt(n));??//求出n的平方根并取整
????????for(i=2;?___(2)___;?i++)
????????if(ni==0)?___(3)___;??
????????if(i>temp)?cout<<n<<?;
????????}
????????cout<<\n;
????????}


34.?采用辗转相除法求出两个整数的最大公约数。
????????#include<iostream.h>
????????void?main()
????????{
????????????int?a,b;
????????cout<<"请输入两个正整数:";
????????cin>>a>>b;
????????while(a<=0?||?__(1)___)?{cout<<"重新输入:";?cin>>a>>b;}
????????while(b)?{
????????int?r;
????????????????r=ab;
????????___(2)___;?___(3)___;??//分别修改a和b的值
????????}
????????cout<<a<<endl;??//输出最大公约数
????????}

35.?把从键盘上输入的一个大于等于3的整数分解为质因子的乘积。如输入24时得到的输出结果为“2?2?2?3”,输入50时得到的输出结果为“2?5?5”,输入37时得到的输出结果为“37”。
????????#include<iostream.h>
????????void?main()
????????{
????????int?x;
????????cout<<"请输入一个整数,若小于3则重输:";
????????do?cin>>x;?while(___(1)___);
????????int?i=2;
????????do{
????????while(___(2)___)?{
????????cout<<i<<?;
????????x/=i;
????????}
????????___(3)___;
????????}while(i<x);
????????if(x!=1)?cout<<x;?
????????cout<<endl;
????????}

36.?下面函数是求两个整型参数a和b的最小公倍数。
???????int?f2(int?a,?int?b)
???????{
???????int?i=2,?p=1;
???????do?{
???????while(ai==0??___(1)___)?{
???????p*=i;?a/=i;?b/=i;
???????}
???????___(2)___;
???????}while(a>=i??___(3)___);
???????return?p*a*b;
???????}
37.?在输出屏幕上打印出一个由字符’*’组成的等腰三角形,该三角形的高为5行,从上到下每行的字符数依次为1,3,5,7,9。
???????#include<iostream.h>
???????void?main()
???????{
???????int?i,j;
???????for(i=1;___(1)___;i++)?{
???????for(j=1;j<=9;j++)
???????if(j<=5-i?||?___(2)___)?cout<<’?’;
???????else?___(3)___;
???????cout<<endl;
???????}
???????}

38.?统计字符串中英文字母个数的程序。
???????#include?<iostream.h>
???????int?count?(char?str[]);
???????void?main(){
???????????char?s1[80];
???????????cout?<<”Enter?a?line:”;
???????????cin?>>s1;
???????????cout?<<”count=”<<count(s1)<<endl;
???????}
???????int?count(char?str[]){
???????????int?num=0;??//给统计变量赋初值
???????????for(int?i=0;str[i];i++)
???????????if?(str[i]>=’a’??str[i]<=’z’?||___(1)___?)
???????????????___(2)___;
???????___(3)___;
???????}

39.?主函数调用一个fun函数将字符串逆序。
???#include<iostream.h>
???????#include<string.h>
???___(1)___;
???void?main(?)?{
???????char?s[80];
???????cin>>s;
???????___(2)___;
???????cout<<”逆序后的字符串:”<<s<<endl?;
???}
???void?fun(char?ss[])?{
???????int?n=strlen(ss);
???????for(int?i=0;?___(3)____;?i++)?{
??????????char?c=ss[i];
??????????ss[i]=ss[n–1–i];
??????????ss[n–1–i]=c;
???????}
???????}

40.?从一个字符串中删除所有同一个给定字符后得到一个新字符串并输出。
???????#include<iostream.h>
???????const?int?len=20;
???????void?delstr(char?a[],char?b[],char?c);
???????void?main()?{
???????char?str1[len],str2[len];
???????????char?ch;
???????cout<<"输入一个字符串:";
???????cin>>str1;
???????cout<<"输入一个待删除的字符:";?
???????????cin>>ch;
???????delstr(str1,str2,ch);
???????????cout<<str2<<endl;
???????}
???????void?delstr(char?a[],char?b[],char?c)
???????{
???????int?j=0;
???????for(int?i=0;?___(1)___;?i++)
???????if(___(2)___)?b[j++]=a[i];
???????b[j]=___(2)___;
???????}

41.?采用指针访问方式从键盘给数组a[N]输入数据,然后对元素值重新按逆序存放并输出。
???????#include?<iostream.h>
???????const?int?N=8;
???????void?main()
???????{
???????????int?a[N],*p,*q;
???????????for(p=a;?p<a+N;?p++)?___(1)___;
???????????p=a;q=a+N-1;
???????????while(p<q)?{
???????????int?r=*p;?*p=*q;?*q=r;
???????????????___(2)___;?___(3)___;
???????}
???????????for(p=a;p<a+N;?p++)
???????????????cout<<*p<<?;
???????????cout<<endl;
???????}

42.?从键盘上输入一个正整数,然后把它转换成的二进制数的每一位存放到一维数组中,最后输出该二进制数。注意二进制数的存放是按照从低位到高位的次序进行的。
???????#include?<iostream.h>
???????void?main()
???????{
???????int?x;
???????????cout<<"输入一个整数:";
???????????cin>>x;
???????????int?a[20],k=0,r;
???????????do?{
???????r=x2;
???????????????a[k++]=r;
???????????????x=___(1)___;
???????}?while(___(2)___);
???????????for(--k;k>=0;k--)?___(3)___;
???????????cout<<endl;
???????}

43.?对数组a[n]按升序进行的选择排序算法
????????void?SelectSort(int?a[],?___(1)___)
????????{
????????int?i,j,k;
????????for(i=1;i<n;i++)?{??//进行n-1次选择和交换
????????????????k=i-1;
????????for(j=i;j<n;j++)
????????if(a[j]<a[k])?___(2)___;
????????int?x=a[i-1];?a[i-1]=a[k];?___(3)___;
????????}
????????}

?44.?对数组a[n]按升序进行的插入排序算法
????????void?InsertSort(___(1)___,?int?n)??
????????{
????????int?i,j,x;
????????for(i=1;i<n;i++)?{??//进行n-1次循环
????????????????x=a[i];
????????for(j=i-1;j>=0;j--)??//为x顺序向前寻找合适的插入位置
????????if(x<a[j])?___(2)___;
????????????????????else?___(3)___;
????????a[j+1]=x;??
????????}
????????}

45.?对按从小到大排列的有序数组a[n]进行二分查找x的算法,若查找成功返回该元素下标,否则返回-1。
????????int?BinarySearch(int?a[],int?x)?
????????{
????????int?low=0,?high=N-1;??//定义并初始化区间下界和上界变量
????????int?mid;??//定义保存中点元素下标的变量
????????while(low<=high)?{
????????mid=___(1)___;
????????if(x==a[mid])?___(2)___;
????????else?if(x<a[mid])?high=mid-1;
????????else?___(3)___;
????????}
????????return?-1;
????????}

46.?用插入排序方法对table指针数组中size个指针所指向的字符串进行按升序排序的算法。
void?sort(char?*table[],?int?size){
????for(int?i=1,___(1)___;?i++){
????????char?*p=table[i];
????????for(int?j=i-1;?j>=0?;?j--)?
????????????if(strcmp(p,table[j])<0)?___(2)___;
????????????else?break;
????????table[j+1]=___(3)___;
????}
}

47.?假定有定义为“struct?NODE{int?data;?NODE*?next;};”,下面算法根据table数组中的n个元素建立一个表头指针为L的链表,链表中结点值的顺序与数组元素值的顺序相同。
void?f5(NODE*?L,?int?table[],?int?n)
{??
if(n<=0)?{L=NULL;?return;}
L=new?NODE;??//生成附加的头结点
int?i=0;?
NODE*?p=L;
while(___(1)___)?{
p=p->next=___(2)___;
p->data=___(3)___;
i++;
}
p->next=NULL;??//把最后一个结点的指针域置空
p=L;
L=L->next;??//使L指向链表的第一个带值的结点
delete?p;
}

48.?假定有定义为“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++;
}
}

49.?假定有定义为“struct?NODE{int?data;?NODE*?next;};”,下面算法是依次显示输出以L为表头指针的链表中各结点的值。
void?f7(NODE*?L)
{
for(___(1)___;?p!=NULL;?___(2)___)
cout<<___(3)___?<<?;
cout<<endl;
}

50.?假定有定义为“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+…+n)。

2.输入N个整数,输出其中最大数。

3.编写一个递归函数计算 。

4.编写一个递归函数计算n!。

5.输入N个整数,输出其中最小数。

6.编程计算100-200之间的素数。

7.编程计算下列级数的和:1-2+3-4+…..+(-1)n-1n。

8.求一个N*N矩阵对角线元素的和。

9.输入N个整数,按大小顺序排序。

10.一个函数判断一个正整数是否为素数。  

11.编写一个函数将一个数组中的值按逆序重现存放。

12.编写程序,统计输入字符串中数字和其它字符的个数。

13.编写函数计算一字符串的长度。

14.编写函数将一个字符串接到另一个字符串后面。               

15.编写程序计算下列级数的和:2+4+6+8+…+2n

16.用程序验证100以内的奇整数,其平方被8整数余一。

17.编程:设计一个自动转换公制和英制尺寸程序。已知一英尺为25.4cm。

18.用公式"π/4 = 1 - 1/3 + 1/5 - 1/7 + 1/9+…"求π的近似值,直到最后一项的值小于10  ,并把结果输出到屏幕。

19.编程求下列表达式的值:
100                50                10
∑ K +        ∑ K2 +        ∑ 1/K
K=1                K=1                K=1

20.编写一个程序,将下列一组成绩{76,83,54,62,40,75,90,93,77,85,100}中的每一个成绩x,按x<60、60≤x<70、70≤x<80、80≤x<90、90≤x≤100五个区段分别统计人数,并把各个区段的人数输出到屏幕。

21.有一个数列,它的第一项为0,第二项为1,以后每一项都是它的前两项之和,编程产生此数列的前20项,并按逆序显示出来。

22.编写一个函数,按给定的半径r计算圆的面积a和周长c。用键盘输入r的值,计算a、c并输出到屏幕。

23.一个数列它的第一项为1,第二项为2,以后第n项是第n-1项2倍和第n-2项之和,编程产生此数列的前10项,并显示出来。           

24.有个三角形,三边为a,b,c,设s0=(p*(p-a)* (p-b) *(p-c)),其中p是周长的二分之一,三角形面积为s0的平方根。用键盘输入a,b,c的值,求出三角形面积并显示出来。

25.输入三个数,输出最大者(要求用条件表达式)。

26.把100至200之间的能被13整除的数输出。

27.把100至200之间的能被23整除的数输出。

28.输入三个数,输出最小者(要求用条件表达式)。

29.求出从1990年至2020年的润年年份,并输出到屏幕;成为润年的条件是以下条件之一的年份:
①年份可以被400整除;
②年份可以被4整除,同时该年份不可以被100整除

30.输入一个三位整数,倒序输出(例如,输入的是125,输出的是521)。

31.输入一个字符,判别它是否为大写字母,若是将它转换成小写字母,若不是,不转换。然后输出最后得到的字符。  

32.输出"百钱买百鸡"问题的所有解(问题是这样的:用100块钱买100只鸡,公鸡5元/只,母鸡3元/只,小鸡1元3只,问供给、母鸡、小鸡多少只)。

33.求一个矩阵的转置矩阵。

34.打印所有的水仙花数,所谓水仙花数是指一个三位数,其各位数字立方和等于该数本身。


35.设计一个有公制转换到英制尺寸程序。已知一英尺为25.4cm。

36.编写一个函数统计字符串中,某字符出现的频率。

37.把100至200之间的能被7整除的数输出。

38.将下列等级成绩:A:85~100; B:85~79; C:60~69: D:0~59; 表达成百分制分数段。

39.编写程序,统计输入字符串中大写字母和其它字符的个数。

40.把1000至2000之间的偶数且能被3整除的数输出。


第二章 类和对象
单项选择题:
1.在下面存储类中, (    ) 对象的可见性与生存期不一致。
A. 外部类            B. 自动类    C. 内部静态类            D. 寄存器类
2.在下面存储类中,(    )的对象不是局部变量。
A. 外部静态类          B. 自动类    C. 函数形参           D. 寄存器类
3.栈具有(   )的操作特性。
A. 先进先出      B. 先进后出      C. 进出无序      D. 进出任意
4.关于消息,下列说法中不正确的是(   )。
A. 发送消息的对象请求服务,接受消息的对象提供服务
B. 消息的发送者必须了解消息的接收者如何相应消息
C. 在C++中,消息的发送具体体现为对接收消息的对象的某个函数的调用
D. 每个对象只能接收某些特定格式的消息
5.关于封装,下列说法中不正确的是(   )。
A. 通过封装,对象的全部属性和操作结合在一起,形成一个整体
B. 通过封装,一个对象的实现细节被尽可能地隐藏起来(不可见)
C. 通过封装,每个对象都成为相对独立的实体
D. 通过封装,对象的属性都是不可见的
6.面向对象方法的多态性是指(   )。
A. 一个类可以派生出多个特殊类
B. 一个对象在不同的运行环境中可以有不同的变体
C. 针对一消息,不同的对象可以以适合自身的方式加以响应
D. 一个对象可以是由多个其他对象组合而成的
7.软件产品在需求发生变化、运行环境发生变化或发现软件产品本身的错误或不足时进行相应的软件更新的难易程度叫做软件的(    )。
A. 可维护性          B. 可复用性    C. 兼容性            D. 正确性
8.软件产品可被全部或部分地再用于新的应用的能力叫做软件的(    )。
A. 可维护性        B. 可复用性   C. 兼容性            D. 正确性
9.软件产品与其他软件产品组合成一个整体的难易程度叫做软件的(    )。
A. 可维护性          B. 可复用性    C. 兼容性            D. 正确性
10.软件产品准确执行软件需求规格说明书中所规定的任务的能力叫做软件的(    )。
A. 可维护性           B. 可复用性   C. 兼容性          D. 正确性
11.面向对象软件开发中使用的OOA表示(   )。
A. 面向对象分析          B. 面向对象设计   C. 面向对象语言           D. 面向对象方法
12.面向对象软件开发中使用的OOD表示(   )。
A. 面向对象分析        B. 面向对象设计   C. 面向对象语言    D. 面向对象方法
13.关于面向对象系统分析,下列说法中不正确的是(    )。
A. 术语“面向对象分析”可以用缩写OOA表示
B. 面向对象分析阶段对问题域的描述比实现阶段更详细
C. 面向对象分析包括问题域分析和应用分析两个步骤
D. 面向对象分析需要识别对象的内部和外部特征
14.在一个类的定义中,包含有(   )成员的定义。
A. 数据      B. 函数      C. 数据和函数      D. 数据或函数
15.在类作用域中能够通过直接使用该类的(   )成员名进行访问。
A. 私有      B. 公用      C. 保护      D. 任何
16.在关键字public后面定义的成员为类的(   )成员。
A. 私有      B. 公用      C. 保护      D. 任何
17.在关键字private后面定义的成员为类的(   )成员。
A. 私有      B. 公用      C. 保护      D. 任何
18.假定AA为一个类,a为该类公有的数据成员,x为该类的一个对象,则访问x对象中数据成员a的格式为(   )。
A. x(a)      B. x[a]      C. x->a      D. x.a
19.假定AA为一个类,a()为该类公有的函数成员,x为该类的一个对象,则访问x对象中函数成员a()的格式为(   )。
A. x.a      B. x.a()      C. x->a      D. x->a()
20.假定AA为一个类,a为该类公有的数据成员,px为指向该类对象的一个指针,则访问px所指对象中数据成员a的格式为(   )。
A. px(a)    B. px[a]      C. px->a      D. px.a
21.假定AA为一个类,a为该类私有的数据成员,GetValue()为该类公有函数成员,它返回a的值,x为该类的一个对象,则访问x对象中数据成员a的格式为(   )。
A. x.a      B. x.a()      C. x->GetValue()      D. x.GetValue()
22.假定AA为一个类,int a()为该类的一个成员函数,若该成员函数在类定义体外定义,则函数头为(   )。
A. int AA::a()           B. int AA:a()    C. AA::a()           D. AA::int a()
23.假定AA为一个类,a为该类公有的数据成员,若要在该类的一个成员函数中访问它,则书写格式为(   )。
A. a        B. AA::a      C. a()      D. AA::a()
24.若需要把一个类外定义的成员函数指明为内联函数,则必须把关键字(   )放在函数原型或函数头的前面。
A. in         B. inline      C. inLine      D. InLiner
25.在多文件结构的程序中,通常把类的定义单独存放于(   )中。
A. 主文件     B. 实现文件      C. 库文件      D. 头文件
26.在多文件结构的程序中,通常把类中所有非内联函数的定义单独存放于(   )中。
A. 主文件     B. 实现文件      C. 库文件      D. 头文件
27.在多文件结构的程序中,通常把含有main()函数的文件称为(   )。
A. 主文件      B. 实现文件      C. 程序文件      D. 头文件
28.一个C++程序文件的扩展名为(   )。
A. .h          B. .c           C. .cpp      D. .cp
29.在C++程序中使用的cin标识符是系统类库中定义的(   )类中的一个对象。
A. istream      B. ostream      C. iostream      D. fstream
30.在C++程序中使用的cout标识符是系统类库中定义的(   )类中的一个对象。
A. istream      B. ostream      C. iostream      D. fstream
31.假定AA是一个类,abc是该类的一个成员函数,则参数表中隐含的第一个参数的类型为(   )。
A. int          B. char         C. AA            D. AA*
32.假定AA是一个类,abc是该类的一个成员函数,则参数表中隐含的第一个参数为(   )。
A. abc           B. *this      C. this      D. this&
33.假定AA是一个类,“AA& abc();”是该类中一个成员函数的原型,若该函数存在对*this赋值的语句,当用x.abc()调用该成员函数后,x的值(   )。
A. 已经被改变        B. 可能被改变    C. 不变           D.不受函数调用的影响
34.假定AA是一个类,“AA* abc()const;”是该类中一个成员函数的原型,若该函数返回this值,当用x.abc()调用该成员函数后,x的值(   )。
A. 已经被改变           B. 可能被改变    C. 不变           D. 受到函数调用的影响
35.类中定义的成员默认为(   )访问属性。
A. public      B. private      C. protected      D. friend
36.结构中定义的成员默认为(   )访问属性。
A. public      B. private      C. protected      D. friend
37.当类中一个字符指针成员指向具有n个字节的存储空间时,它所能存储字符串的最大长度为(   )。
A. n           B. n+1          C. n-1            D. n-2
38.在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则队尾(即最后一个)元素的位置为(   )。
A. length+1                                  B. first+length
C. (first+length-1)%MS                      D. (first+length)%MS
39.在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则队尾的后一个位置为(   )。
A. length+1          B. first+length     C. (first+length-1)%MS           D. (first+length)%MS
40.在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则队首的后一个位置为(   )。
A. first+1           B. (first+1)%MS     C. (first-1)%MS             D. (first+length)%MS
41.在一个用链表实现的队列类中,假定每个结点包含的值域用elem表示,包含的指针域用next表示,链队的队首指针用elemHead表示,队尾指针用elemTail表示,若链队非空,则进行插入时必须把新结点的地址赋给(   )。
A. elemHead                              B. elemTail
C. elemHead->next和elemHead                D. elemTail->next和elemTail
42.在一个用链表实现的队列类中,假定每个结点包含的值域用elem表示,包含的指针域用next表示,链队的队首指针用elemHead表示,队尾指针用elemTail表示,若链队为空,则进行插入时必须把新结点的地址赋给(   )。
A. elemHead                                        B. elemTail
C. elemHead和elemTail                             D. elemHead或elemTail
43.队列具有(   )的操作特性。
A. 先进先出      B. 先进后出      C. 进出无序      D. 进出任意

填空题:
1.?在一个用链表实现的队列类中,若链队为空或只含有一个结点,则队首指针的值与队尾指针的值(  )。
2.?在一个用链表实现的队列类中,若队首指针与队尾指针的值不同,则说明链队中至少包含有(  )个结点。
3.?以面向对象方法构造的系统,其基本单位是(  )。
4.?每个对象都是所属类的一个(  )。
5.?对象将其大部分实现细节隐藏起来,这种机制称为(  )。
6.?基类和派生类的关系称为(  )。
7.?复杂对象可以由简单对象构成,这种现象称为(  )。
8.?对象是对问题域中客观事物的( 抽象 ),它是一组属性和在这些属性上操作的(  )。
9.?特殊类的对象拥有其一般类的全部属性与操作,称特殊类(  )了一般类。
10.?如果一个派生类的基类不止一个,则这种继承称为( 继承多继承( )。
11.?如果一个派生类只有一个唯一的基类,则这样的继承关系称为(  )。
12.?C++支持两种多态性:(  )时的多态性和(  )时的多态性。
13.?在C++中,编译时的多态性是通过(  )实现的,而运行时的多态性则是通过(  )实现的。
14.?面向对象软件开发的生命周期分为三个阶段,即分析、(  )和(  )。
15.?面向对象的分析包括(  )分析和(  )分析两步。
16.?类定义中,既包含数据成员,也包含(  )成员。
17.?类中的数据成员的访问属性通常被指明为(  )。
18.?类中的供外部调用定义的函数成员,其访问属性通常被定义为(  )。
19.?对于类中定义的任何成员,其隐含访问权限为(     )。
20.?对于结构中定义的任何成员,其隐含访问权限为(      )。
21.?为了使类中的成员不能被类外的函数通过成员操作符访问,则应把该成员的访问权限定义为(  )。?
22.?若在类的定义体中给出了一个成员函数的完整定义,则该函数属于(   )函数。
23.?若在类的定义体中只给出了一个成员函数的原型,则在类外给出完整定义时,其函数名前必须加上(     )和两个冒号分隔符。
24.?若在类的定义体中只给出了一个成员函数的原型,则在类外给出完整定义时,其函数名前必须加上类名和两个(  )分隔符。
25.?若要把类外定义的成员函数规定为内联函数,则必须把(    )关键字放到函数原型或函数头的前面。?
26.?把一个类的定义体和所有成员函数的定义体所构成的程序范围叫做该类的( )。
27.?假定AA是一个类,“AA*?abc();”是该类中一个成员函数的原型,则在类外定义时的函数头为(  )。
28.?成员函数的参数表在类作用域中,成员函数的返回值类型(  )类作用域中。
29.?为了避免在调用成员函数时修改对象中的任何数据成员,则应在定义该成员函数时,在函数头的后面加上(    )关键字。?
30.?若只需要通过一个成员函数读取数据成员的值,而不需要修改它,则应在函数头的后面加上(  )关键字。?
31.?若采用x.abc(y)表达式调用一个成员函数,在成员函数中使用的(  )就代表了类外的x对象。?
32.?若采用p->abc(y)表达式调用一个成员函数,在成员函数中使用的(    )就代表了类外的p指针。?
33.?内联函数的定义模块与(  )模块必须放在同一个文件中。
34.假定AA是一个类,“AA*?abc()const;”是该类中一个成员函数的原型,在该函数体中(   )(     )向*this或其成员赋值。
35.在一个用数组实现的队列类中,包含有两个数据成员,一个指明队首元素位置,另一个指明(  )。
36.?在一个用数组实现的队列类中,包含有两个数据成员,一个指明队列长度,另一个指明(  )元素的位置。
37.?在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则插入一个新元素的位置为(  )。
38.?在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则删除一个元素后队首的位置为(    )。
39.?在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则队列为空的条件为(  )。
40.?在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则队列为满的条件为(    )。
41.?当一个队列为空时,不能对其做(  )元素的操作。
42.?当一个队列为满时,不能对其做(  )元素的操作。
43.从一个队列中删除元素就是删除(  )位置上的元素。
44.向一个队列中插入元素就是把该元素放到(   )元素的后一位置上。
45.在一个用链表实现的队列类中,假定每个结点包含的值域用elem表示,包含的指针域用next表示,链队的队首指针用elemHead表示,队尾指针用elemTail表示,当链队非空时,(    )指向队首结点的后继(   )结点。
46.?在一个用链表实现的队列类中,假定每个结点包含的值域用elem表示,包含的指针域用next表示,链队的队首指针用elemHead表示,队尾指针用elemTail表示,当链队非空时,新插入结点的地址应当赋给(    )所指结点的next域。
47.?在一个用链表实现的队列类中,队尾结点的指针域的值为(     )。
48.?在一个用链表实现的队列类中,若链队中只含有一个结点,则队首指针的值与队尾指针的值(    )。

简答题:
文件包含预编译指令#include ,有那两种格式,它们有什么区别?

简述面向对象程序设计方法相对于面向过程的程序设计方法的优越性。

简述什么是类,并举例说明。

简述什么是对象,并举例说明。

简述C中结构与C++中类的区别。

简述C++中类的成员函数的三种访问方法。

简述类和对象的区别与联系并举例说明。

简述类对其成员的三种存储控制及作用结果。

简述C++程序在内存中的分配格局。

简述 C和C++动态内存的使用。

简述什么是先期联编,什么是迟后联编。


程序填空题:
?1.?已知一个类的定义如下:
#include<iostream.h>
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个元素
};

????该类中MaxA()函数的实现如下,请在标号位置补充适当的内容。
int?____(1)_____?
{
int?x=a[0];
for(int?i=1;?i<n;?i++)?
if(a[i]>x)?___(2)___;
___(3)___;
}

2.?已知一个类的定义如下:
#include<iostream.h>
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<n;?j++)
if(a[j]<x)?___(2)___
a[k]=a[i];
___(3)___;
}
}

3.?已知一个类的定义如下:
#include<iostream.h>
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?___(1)___?
{
int?i,j;
for(i=1;?i<n;?i++)?{
int?x=a[i];
for(j=i-1;?j>=0;?j--)
if(x<a[j])?___(2)___;
else?___(3)___;
a[j+1]=x;
}
}

4.?已知一个类的定义如下:
#include<iostream.h>
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?main()
{
int?a[10]={23,78,46,55,62,76,90,25,38,42};
AA?x;??
___(1)___;
int?m=___(2)___;
___(3)___;
cout<<m<<endl;
}
????该程序运行结果为:
23?78?46?55?62?76
78

5.?已知一个类的定义如下:
#include<iostream.h>
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?PrintA();??//依次输出数组a中的前n个元素,
????????????????????//最后输出一个换行
};

????使用该类的主函数如下:
void?main()
{
int?a[10]={23,78,46,55,62,76,90,25,38,42};
___(1)___;??
x.SetA(a,8);
int?___(2)___;
___(3)___;
x.PrintA();
????cout<<m<<endl;
}

????该程序运行结果为:
23?25?46?55?62?76?78?90
90

6.?已知一个利用数组实现栈的类定义如下:
const?int?ARRAY_SIZE=10;
class?Stack?{
public:
void?Init()?{top=-1;}???????//初始化栈为空
????void?Push(int?newElem);?????//向栈中压入一个元素
int?Pop();??????????????????//从栈顶弹出一个元素
bool?Empty()?{??//判栈空
????????if(top==-1)?return?true;else?return?false;}
int?Depth()?{return?top+1;}??//返回栈的深度
void?Print();??
????????//按照后进先出原则依次输出栈中每个元素,直到栈空为止
private:
int?elem[ARRAY_SIZE];??//用于保存栈元素的数组
int?top;???????????????//指明栈顶元素位置的指针
};

void?Stack:ush(int?newElem)?{
if(___(1)___)?{?
cout<<"栈满!"<<endl;
exit(1);??//中止运行
}
___(2)___;
elem[top]=___(3)___;
}

7.?已知一个利用数组实现栈的类定义如下:
const?int?ARRAY_SIZE=10;
class?Stack?{
public:
void?Init()?{top=-1;}?????//初始化栈为空
????void?Push(int?newElem);???//向栈中压入一个元素
int?Pop();????????????????//从栈顶弹出一个元素
bool?Empty()?{??//判栈空
????????if(top==-1)?return?true;else?return?false;}
int?Depth()?{return?top+1;}??//返回栈的深度
void?Print();??
????????//按照后进先出原则依次输出栈中每个元素,直到栈空为止
private:
int?elem[ARRAY_SIZE];??//用于保存堆栈元素的数组
int?top;???????????????//指明栈顶元素位置的指针
};

????该类的Pop和Print函数的实现分别如下:
___(1)___?{
if(top==-1)?{
cout<<"栈空!"<<endl;
exit(1);??//中止运行
}
return?___(2)___;
}

void?Stack:rint()?{
while(!Empty())?
cout<<___(3)___?<<?;
}

写出程序的执行结果:
程序设计与分析题:
1.?根据下面类中Count函数成员的原型和注释写出它的类外定义。(﹡﹡﹡)
class?AA?{
int*?a;
int?n;
int?MS;
public:
void?InitAA(int?aa[],?int?nn,?int?ms)?{
if(nn>ms)?{cout<<"Error!"<<endl;?exit(1);}
MS=ms;
n=nn;
a=new?int[MS];
for(int?i=0;?i<MS;?i++)?a[i]=aa[i];
}
int?Count(int?x);??//从数组a的前n个元素中统计出其
???????????????????????//值等于x的个数并返回。
};

2.?根据下面类中Search函数成员的原型和注释写出它的类外定义。(﹡﹡﹡)
class?AA?{
int*?a;
int?n;
int?MS;
public:
void?InitAA(int?aa[],?int?nn,?int?ms)?{
if(nn>ms)?{cout<<"Error!"<<endl;?exit(1);}
MS=ms;
n=nn;
a=new?int[MS];
for(int?i=0;?i<MS;?i++)?a[i]=aa[i];
}
????int?Search(int?x);?//从数组a的前n个元素中顺序查找值为x的元素,
???????????????????//若查找成功则返回元素的下标,否则返回-1。
};

3.?根据下面类中MaxMin?函数成员的原型和注释写出它的类外定义。(﹡﹡﹡)
class?AA?{
int*?a;
int?n;
int?MS;
public:
void?InitAA(int?aa[],?int?nn,?int?ms)?{
if(nn>ms)?{cout<<"Error!"<<endl;?exit(1);}
MS=ms;
n=nn;
a=new?int[MS];
for(int?i=0;?i<MS;?i++)?a[i]=aa[i];
}
int?MaxMin(int?x,?int?y);?//从数组a的前n个元素中求出
?????????//最大值和最小值,并分别由引用参数x和y带回,
?????????//同时若n大于0则返回1,否则返回0。
};

4.?根据下面类中Compare?函数成员的原型和注释写出它的类外定义。(﹡﹡﹡)
class?AA?{
int*?a;
int?n;
int?MS;
public:
void?InitAA(int?aa[],?int?nn,?int?ms)?{
if(nn>ms)?{cout<<"Error!"<<endl;?exit(1);}
MS=ms;
n=nn;
a=new?int[MS];
for(int?i=0;?i<MS;?i++)?a[i]=aa[i];
}
int?Compare(AA?b);?//比较*this与b的大小,若两者中
????????//的n值相同,并且数组中前n个元素值对应
????????//相同,则认为两者相等返回1,否则返回0。
};

5.?根据下面类中CompareBig?函数成员的原型和注释写出它的类外定义。(﹡﹡﹡)
class?AA?{
int*?a;
int?n;
int?MS;
public:
void?InitAA(int?aa[],?int?nn,?int?ms)?{
if(nn>ms)?{cout<<"Error!"<<endl;?exit(1);}
MS=ms;
n=nn;
a=new?int[MS];
for(int?i=0;?i<MS;?i++)?a[i]=aa[i];
}
int?CompareBig(AA?b);??//比较*this与b的大小,从前向后按两数组
???????????//中的对应元素比较,若*this中元素值大则返回1,若b中
???????????//元素值大则返回-1,若相等则继续比较下一个元素,直到
???????????//一个数组中无元素比较,此时若两者的n值相同则返回0,
???????????//否则若*this中的n值大则返回1,若b中的n值大则返回-1。
};

6.?根据下面类中Reverse?函数成员的原型和注释写出它的类外定义。(﹡﹡﹡)
class?AA?{
int*?a;
int?n;
int?MS;
public:
void?InitAA(int?aa[],?int?nn,?int?ms)?{
if(nn>ms)?{cout<<"Error!"<<endl;?exit(1);}
MS=ms;
n=nn;
a=new?int[MS];
for(int?i=0;?i<MS;?i++)?a[i]=aa[i];
}
AA*?Reverse();??//对于调用该函数的对象,将其a数组中前n个
???????//元素值按相反的次序排列,返回指向该对象的指针。
};

7.?根据下面类中Reverse1函数成员的原型和注释写出它的类外定义。(﹡﹡﹡)
class?AA?{
int*?a;
int?n;
int?MS;
public:
void?InitAA(int?aa[],?int?nn,?int?ms)?{
if(nn>ms)?{cout<<"Error!"<<endl;?exit(1);}
MS=ms;
n=nn;
a=new?int[MS];
for(int?i=0;?i<MS;?i++)?a[i]=aa[i];
}
AA*?Reverse1();??//通过动态存储分配得到一个对象,并动态分配
?????//a[MS]数组空间,要求该对象中的n和MS的值与*this中的
?????//对应成员的值相同,数组元素的值是按照*this中数组元
?????//素的相反次序排列得到的,要求该函数返回动态对象的地址。
};


第三章 构造函数
单项选择题:
1.定义类的关键字是(      )。
A.class    B.struct    C.union   D.enum
2.在类中说明的私有成员使用的关键字是(      )。
A.private  B.extern   C.auto  D.public
3.对类中引用成员的初始化是通过构造函数中给出的(    )实现的。
A. 函数体   B. 参数表    C. 初始化表    D. 初始化表或函数体
4.类的构造函数可以带有(    )个参数。
A. 0      B. 1      C. 2      D. 任意
5.对于一个类的构造函数,其函数名与类名(    )。
A. 完全相同      B. 基本相同      C. 不相同      D. 无关系
6.对于一个类的析构函数,其函数名与类名(    )。
A. 完全相同      B. 完全不同      C. 只相差一个字符      D. 无关系
7.类的构造函数是在定义该类的一个(    )时被自动调用执行的。
A. 成员函数      B. 数据成员      C. 对象      D. 友元函数
8.类的析构函数是一个对象被(    )时自动调用的。
A. 建立          B. 撤消          C. 赋值        D. 引用
9.一个类的构造函数通常被定义为该类的(    )成员。
A. 公用          B. 保护          C. 私有        D. 友元
10.一个类的析构函数通常被定义为该类的(    )成员。
A. 私有          B. 保护           C. 公用      D. 友元
11.假定AB为一个类,则执行 “AB x;”语句时将自动调用该类的(    )。
A. 带参构造函数          B. 无参构造函数   C. 拷贝构造函数           D. 赋值重载函数
12.假定AB为一个类,则执行 “AB x(a,5);”语句时将自动调用该类的(    )。
A. 带参构造函数          B. 无参构造函数   C. 拷贝构造函数                   D. 赋值重载函数
13.假定AB为一个类,则执行 “AB *s=new AB(a,5);”语句时得到的一个动态对象为_______。
A. s        B. s->a        C. s.a        D. *s
14.假定AB为一个类,则执行 “AB r1=r2;”语句时将自动调用该类的(    )。
A. 无参构造函数          B. 带参构造函数   C. 赋值重载函数           D. 拷贝构造函数
15.若需要使类中的一个指针成员指向一块动态存储空间,则通常在(    )函数中完成。
A. 析构      B. 构造      C. 任一成员      D. 友元
16.当类中的一个整型指针成员指向一块具有n*sizeof(int)大小的存储空间时,它最多能够存储(    )个整数。
A. n         B. n+1       C. n-1      D. 1
17.假定一个类的构造函数为 “A(int aa, int bb) {a=aa; b=aa*bb;}”,则执行 “A  x(4,5);”语句后,x.a和x.b的值分别为(    )。
A. 4和5     B. 5和4      C. 4和20      D. 20和5
18.假定一个类的构造函数为 “A(int aa=1, int bb=0) {a=aa; b=bb;}”,则执行 “A x(4);”语句后,x.a和x.b的值分别为(    )。
A. 1和0     B. 1和4      C. 4和1       D. 4和0
19.假定AB为一个类,则(    )为该类的拷贝构造函数的原型说明。
A. AB(AB x);           B. AB(AB& x);    C. void AB(AB& x);           D. AB(int x);
20.假定一个类的构造函数为 “B(int ax, int bx): a(ax), b(bx) {}”,执行 “B x(1,2),y(3,4);x=y;”语句序列后x.a的值为(    )。
A. 1           B. 2           C. 3           D. 4
21.假定一个类AB只含有一个整型数据成员a,当用户不定义任何构造函数时,系统为该类定义的无参构造函数为(    )。
A. AB() {a=0;}           B. AB(int aa=0): a(aa) {}    C. AB(int aa): a(aa) {}           D. AB() {}
22.假定一个类AB只含有一个整型数据成员a,用户为该类定义的带参构造函数可以为(    )。
A. AB() {}            B. AB(): a(0){}    C. AB(int aa=0) {a=aa;}          D. AB(int aa) {}
23.对于任一个类,用户所能定义的构造函数的个数至多为(    )。
A. 0      B. 1      C. 2      D. 任意个
24.对于任一个类,用户所能定义的析构函数的个数至多为(    )。
A. 0      B. 1      C. 2      D. 任意个
25.假定AB为一个类,则执行 “AB *px=new AB[n];”语句时将(    )。
A. 动态分配一个数组   B. 动态分配一个对象  C. 静态分配一个数组           D. 静态分配一个对象
26.设px是指向一个类对象的指针变量,则执行 “delete px;”语句时,将自动调用该类的(    )。
A. 无参构造函数        B. 带参构造函数   C. 析构函数          D. 拷贝构造函数
27.当一个类对象离开它的作用域时,系统自动调用该类的(    )。
A. 无参构造函数            B. 带参构造函数   C. 拷贝构造函数          D. 析构函数
28.假定一个类对象数组为A[n],当离开它定义的作用域时,系统自动调用该类析构函数的次数为(    )。
A. 0      B. 1      C. n      D. n-1
29.假定AB为一个类,则执行 “AB a[10];”语句时调用该类无参构造函数的次数为(    )。
A. 0      B. 1      C. 9      D. 10
30.假定AB为一个类,则执行 “AB *px=new AB[n];”语句时调用该类无参构造函数的次数为(    )。
A. n      B. n-1      C. 1      D. 0
31.假定AB为一个类,则执行 “AB a, b(3), *p;”语句时共调用该类构造函数的次数为(    )。
A. 2      B. 3      C. 4      D. 5
32.假定AB为一个类,则执行 “AB a(2), b[3], *p[4];”语句时共调用该类构造函数的次数为(    )。
A. 3      B. 4      C. 5      D. 9
33.. 假定AB为一个类,则执行“AB a, b(2), c[3], *p=&a;”语句时共调用该类无参构造函数的次数为(    )。
A. 5      B. 6      C. 3      D. 4
34.假定AB为一个类,则执行“AB *p=new AB(1,2);”语句时共调用该类构造函数的次数为(    )。
A. 0      B. 1      C. 2      D. 3
35.假定AB为一个类,px为指向该类的一个含有n个对象的动态数组的指针,则执行“delete []px;”语句时共调用该类析构函数的次数为(    )。
A. 0      B. 1      C. n      D. n+1
36.对类对象成员的初始化是通过构造函数中给出的(    )实现的。
A. 函数体        B. 初始化表   C. 参数表           D. 初始化表或函数体
37.对类中常量成员的初始化是通过构造函数中给出的(    )实现的。
A. 函数体           B. 参数表    C. 初始化表             D. 初始化表或函数体
38.类的析构函数可以带有(    )个参数。
A. 0      B. 1      C. 2      D. 任意

填空题:
1.一个类的(  )函数实现对该类对象的初始化功能。
2.一个类的(  )函数通常用于实现释放该类对象中指针成员所指向的动态存储空间的任务。
3.当用户为一个类定义有(  )时,则系统不会为该类再自动生成一个默认构造函数。
4.假定用户没有给一个名为AB的类定义构造函数,则系统为其定义的构造函数为(  )。
5.假定用户没有给一个名为AB的类定义析构函数,则系统为其定义的析构函数为(  ) 。
6.定义类动态对象数组时,其元素只能靠自动调用该类的(  )来进行初始化。
7.在一个类中定义拷贝构造函数的目的,是为了当利用该类的一个对象初始化另一个对象时,能够避免这两个对象的同一指针同时指向同一块(  )。
8.为了释放类对象中指针成员所指向的动态存储空间,则需要为该类定义(  )。
9.?假定?AB为一个类,则执行“AB?a[10];”语句时,系统自动调用该类构造函数的次数为(  )  。
10.假定一个类对象数组为A[N],当离开它的作用域时,系统自动调用该类析构函数的次数为(  )。
11.对类中对象成员的初始化是通过在构造函数中给出的(     )来实现的。
12.对类中常量成员的初始化是通过在构造函数中给出的(     )来实现的。
13.对类中引用成员的初始化只能通过在构造函数中给出的(      )来实现。
14.对类中一般数据成员的初始化既可以通过在构造函数中给出的初始化表来实现,也可以通过构造函数中的(    )来实现。
15.?假定要把aa定义为AB类中的一个常量整数型数据成员,则定义语句为(      )。
16.?假定要把aa定义为AB类中的一个引用整数型数据成员,则定义语句为(      )。
17.?假定AB类中只包含一个整型数据成员a,并且它是一个常量成员,若利用参数aa对其进行初始化,则该类的构造函数的定义为(     )。
18.?假定AB类中只包含一个整型数据成员a,并且它是一个引用成员,若利用引用参数aa对其进行初始化,则该类的构造函数的定义为(        )。
19.假定指针p指向一个动态分配的类对象,则当执行“delete?p;”语句时,在释放p所指向的动态存储空间之前将自动调用该类的(    )。
20.假定用户为类AB定义了一个构造函数“AB(int?aa)?{a=aa;}”,则系统(会/不会)(    )为该类自动定义一个无参构造函数"AB()?{}"。
21.?假定用户为类AB定义了一个构造函数“AB(int?aa,?char?*bb=NULL):a(aa),b(bb){}”,则该类中至少包含有(  )  个数据成员。
22.假定用户为类AB定义了一个构造函数“AB(int?aa)?{a=aa;}”,该构造函数实现对数据成员(  )的初始化。
23.假定用户为类AB定义了一个构造函数“AB(int?aa=0):a(aa){}”,则定义该类的对象时,可以有(  )种不同的定义格式。
24.假定用户为类AB定义了一个构造函数“AB(int?aa):a(aa){}”,则定义该类的对象时,有(  )种定义格式。
25.假定用户只为类AB定义了一个构造函数“AB(int?aa,?int?bb=0)?{a=aa;?b=bb;}”,则定义该类的对象时,其实参表中至多带有(  )个实参。
26.假定用户只为类AB定义了一个构造函数“AB(int?aa,?int?bb=0)?{a=aa;?b=bb;}”,则定义该类的对象时,其实参表中至少带有(  )个实参。
27.假定用户为类AB定义了一个构造函数“AB(int?aa=0,?int?bb=0)?{a=aa;?b=bb;}”,则定义该类的对象时,可以有(   )种不同的定义格式。
28.假定用户只为类AB定义了一个构造函数“AB():a(0),b(0){}”,则定义该类对象x的定义语句“AB?x();”是(      )(     )的。
29.假定用户只为类AB定义了一个构造函数“AB():a(0),b(0){}”,则定义该类对象x的定义语句“AB?x;”是__(    ) __(      )的。
30.假定用户只为类AB定义了一个构造函数“AB():a(0),b(0){}”,则定义该类对象x的定义语句“AB?x(5);”是__(    ) __(     )的。
31.假定AB为一个类,则类定义体中的“AB(AB?x);”语句为该类(      )的原型语句。
32.假定AB为一个类,则该类的拷贝构造函数的函数头为(     )。
33.假定AB为一个类,该类中含有一个指向动态数组空间的指针成员pa,则在该类的析构函数中应该包含有一条(        )语句。

简答题:
简述什么是浅拷贝和深拷贝。

程序设计与分析题:
1.程序: (﹡﹡﹡)
#include <iostream.h>
#include <math.h>
class Point{
public:
  void Set(double ix,double iy)    //设置坐标
  {    x=ix;  y=iy;  }
  double xOffset()         //取y轴坐标分量
  {    return x;  }
  double yOffset()      //取x轴坐标分量
  {    return y;  }
  double angle()        //取点的极坐标
  {    return (180/3.14159)*atan2(y,x);  }
  double radius()        //取点的极坐标半径
  {    return sqrt(x*x+y*y);  }
protected:
  double x;      //x轴分量
  double y;      //y轴分量
};
void main()
{  Point p;
  double x,y;
  for(;;){      //重复输入x和y轴分量,直到x分量值小于0
    cout <<"Enter x and y:\n";
    cin >>x >>y;
    if(x<0)
      break;
    p.Set(x,y);
    cout <<"angle=" <<p.angle()
         <<",radius=" <<p.radius()
         <<",x offset=" <<p.xOffset()
         <<",y offset=" <<p.yOffset() <<endl;
  }
}
问题: 根据类的封装性,不改变该类的公有接口,不改写主函数的情况下,只改变该点类的定义与实现,要求把原有点类的私有成员x,y改写成另外两个私有数据成员a,r分别代表该点在极坐标系下的弧度值和半径值。请写出修改后的类的定义与实现。


2.?根据下面类中构造函数的原型和注释写出它的类外定义。(﹡﹡﹡)
class?Array?{
int?*a;??//指向动态分配的整型数组空间
int?n;????//记录数组长度
public:
Array(int?aa[],?int?nn);??//构造函数,利用aa数组长度nn初始化n,
??????????????????????????//利用aa数组初始化a所指向的数组空间
Array(Array?aa);???//拷贝构造函数
Array?Give(Array?aa);??//实现aa赋值给*this的功能并返回*this
????Array?Uion(Array?aa);???//实现*this和aa中的数组合并的
?????????????????????//功能,把合并结果存入临时对象并返回
int?Lenth()?{return?n;}??//返回数组长度
void?Print()?{???????//输出数组
for(int?i=0;?i<n;?i++)
cout<<a[i]<<?;
????cout<<endl;
}
};

第四章  堆和拷贝构造函数
程序填空题:
1.class?A?{      
?????int?a;
???public:
?????A()?{a=0;}
?????___(1)___{}??//定义构造函数,用参数aa初始化数据成员a
???};
???main()?{
?????___(2)___;??//定义类A的指针对象p
?????___(3)__;???//用p指向动态对象并初始化为整数5
???}

2.class?A?{         
?????char?*a;
???public:
?????___(1)___??//定义无参构造函数,使a的值为空
?????A(char?*aa)?{
???????a=___(2)___;??
???????strcpy(a,aa);??//用aa所指字符串初始化a所指向的动态存储空间
?????}
?????___(3)___??//定义析构函数,删除a所指向的动态存储空间
???};

3.class?A?{         
??????int?a,b;
????public:
??????A(int?aa=0,?int?bb=0)?___(1)___?{}?//分别用aa和bb对应初始化a和b
????};
main()?{
??___(2)___?;??//定义类A的对象x并用5初始化,同时定义y并用x初始化
??___(3)___?;??//定义p指针,使之指向对象x
}

4.class?A?{     
??????int?a,b;
????public:
??????___(1)___?//定义构造函数,使参数aa和bb的默认值为0,
????????????????//在函数体中用aa初始化a,用bb初始化b
????};
main()?{
??A?*p1,?*p2;
??___(2)___?;??//调用无参构造函数生成由p1指向的动态对象
??___(3)___?;??//调用带参构造函数生成由p2指向的动态对象,
???????????????//使a和b成员分别被初始化为4和5
}

5.?#include<iostream.h>   
????#include<stdlib.h>
????class?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(n>MaxLen)?exit(1);
????????___(1)___;??//由a指向长度为MaxLen的动态数组
????????for(int?i=0;?i<n;?i++)?a[i]=aa[i];
??????}??
??????~A()?{delete?[]a;}
??????int?GetValue(int?i)?___(2)___?//函数体返回a[i]的值
????};
????void?main()
????{
????????int?b[10]={1,2,3,4,5,6,7,8,9,10};
????A?r(b,10,10);
????????int?i,s=0;
????????for(i=0;?i<10;?i++);?___(3)___?//把r对象的a数据成员中的每个
???????????????????????????????????????//元素值依次累加到s中
????????cout<<"s="<<s<<endl;
????}

6.?#include<iostream.h>      
????#include<stdlib.h>
????class?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(n>MaxLen)?exit(1);
????????a=new?int[MaxLen];
????????___(1)___;??//以i为循环变量把aa数组中每个元素值
????????????????????//传送给a数组的对应元素中
??????}??
??????~A();
??????int?GetValue(int?i)?{return?a[i];}?//函数体返回a[i]的值
};

___(2)___???//析构函数的类外定义
????
????void?main()
????{
????????int?b[10]={1,2,3,4,5,6,7,8,9,10};
????A?r(b,10,10);
????????int?i,s=0;
????????___(3)___?;?//以i为循环变量,把r对象的a数据成员中的
????????????????????//每个元素值依次累加到s中
????????cout<<"s="<<s<<endl;
????}

写出程序的执行结果:
1. 请写出下面程序的运行结果:
程序:
#include <iostream.h>
class Tdate{
public:
  Tdate();
  Tdate(int d);
  Tdate(int m,int d);
  Tdate(int m,int d,int y);
  //其他公共成员
protected:
  int month;
  int day;
  int year;
};

Tdate::Tdate()
{
  month=4; day=15; year=1995;
  cout <<month <<"/" <<day <<"/" <<year <<endl;
}
Tdate::Tdate(int d)
{
  month=4; day=d; year=1996;
  cout <<month <<"/" <<day <<"/" <<year <<endl;
}
Tdate::Tdate(int m,int d)
{
  month=m; day=d; year=1997;
  cout <<month <<"/" <<day <<"/" <<year <<endl;
}
Tdate::Tdate(int m,int d,int y)
{
  month=m; day=d; year=y;
  cout <<month <<"/" <<day <<"/" <<year <<endl;
}

void main()
{
  Tdate aday;
  Tdate bday(10);
  Tdate cday(2,12);
  Tdate dday(1,2,1998);
}


程序设计与分析题:
1. 程序:(﹡﹡﹡)
   # include <iostream.h>                      //  (1)
   class  Clock         
   {
public:
     Clock (int H=0,int M=0, int S=0)         //  (2)
        {Hour=H ;Minute=M ;Second=S;}     //  (3)
      Clock ( Clock  & c)                  //  (4)
        { Hour=c.Hour;Minute=c.Minute;Second=c.Second;}// (5)
      void SetTime (int H=0,int M=0,int S=0)             // (6)
        {Hour=H ;Minute=M ;Second=S;}               // (7)
      void ShowTime ()                               // (8)
        {cout <<Hour<< “:” <<Minute<< “:” <<Second <<endl;   // (9)
      ~Clock () { }                                        // (10)
private:
    int Hour , Minute , Second;                               // (11)
};
void  main( void )
{
    Clock meClock (8,30,0);                                   // (12)
    MeClock.ShowTime ( );                                    // (13)
    Clock yourClock (meClock);                                // (14)
    yourClock.SetTime ( );                                     // (15)
     yourClock.ShowTime( );                                   // (16)
}
问题:
指出Clock类的外部接口的行号。
指出Clock类的构造函数和拷贝构造函数以及析构函数所在行号。
执行那行语句时系统自动调用了构造函数并写出被初始化的对象名。
执行那行语句时系统调用了拷贝构造函数并写出被初始化的对象名。
写出程序的运行结果。

2.?根据下面类中拷贝构造函数的原型写出它的类外定义。(﹡﹡﹡)
class?Array?{
int?*a;??//指向动态分配的整型数组空间
int?n;????//记录数组长度
public:
Array(int?aa[],?int?nn);??//构造函数,利用aa数组长度nn初始化n,
??????????????????????????//利用aa数组初始化a所指向的数组空间
Array(Array?aa);??//拷贝构造函数
Array?Give(Array?aa);??//实现aa赋值给*this的功能并返回*this
????Array?Uion(Array?aa);???//实现*this和aa中的数组合并的
?????????????????????????//功能,把合并结果存入临时对象并返回
int?Lenth()?{return?n;}??//返回数组长度
void?Print()?{???????????//输出数组
for(int?i=0;?i<n;?i++)
cout<<a[i]<<?;
????cout<<endl;
}
};

3.?根据下面类中Give函数的原型和注释写出它的类外定义。(﹡﹡﹡)
class?Array?{
int?*a;??//指向动态分配的整型数组空间
int?n;????//记录数组长度
public:
Array(int?aa[],?int?nn);??//构造函数,利用aa数组长度nn初始化n,
????????????????????//利用aa数组初始化a所指向的数组空间
Array(Array?aa);??//拷贝构造函数
Array?Give(Array?aa);??//实现aa赋值给*this的功能并返回*this
????Array?Uion(Array?aa);??//实现*this和aa中的数组合并的
?????????????????????//功能,把合并结果存入临时对象并返回
int?Lenth()?{return?n;}??//返回数组长度
void?Print()?{???????//输出数组
for(int?i=0;?i<n;?i++)
cout<<a[i]<<?;
????cout<<endl;
}
};

4.?根据下面类中Uion?函数的原型和注释写出它的类外定义。(﹡﹡﹡)
class?Array?{
int?*a;??//指向动态分配的整型数组空间
int?n;????//记录数组长度
public:
Array(int?aa[],?int?nn);??//构造函数,利用aa数组长度nn初始化n,
????????????????????//利用aa数组初始化a所指向的数组空间
Array(Array?aa);??//拷贝构造函数
Array?Give(Array?aa);??//实现aa赋值给*this的功能并返回*this
Array?Uion(Array?aa);??//实现*this和aa中的数组合并的功能,把合并
??????????????????//结果(其长度为两数组长度之和)存入临时对象并返回
int?Lenth()?{return?n;}??//返回数组长度
void?Print()?{???????//输出数组
for(int?i=0;?i<n;?i++)
cout<<a[i]<<?;
????cout<<endl;
}
};

5.?根据下面类中构造函数的原型和注释写出它的类外定义。(﹡﹡﹡)
class?Strings?{
char?*s;??//指向动态分配的字符串数组空间
int?n;????//记录字符串长度
public:
Strings(char*str);??//构造函数,利用str字符串长度初始化n,
????????????????????//利用str字符串初始化s所指的字符串空间
Strings(Strings?str);????????//拷贝构造函数
Strings?Give(Strings?str);??//实现str赋值给*this的功能
????Strings?Uion(Strings?str);???//实现*this和str中的字符串合并的
?????????????????????//功能,把合并结果存入临时对象并返回
int?Lenth()?{return?n;}???????//返回字符串长度
void?Print()?{cout<<s<<endl;}?//输出字符串
};

6.?根据下面类中拷贝构造函数的原型写出它的类外定义。(﹡﹡﹡)
class?Strings?{
char?*s;??//指向动态分配的字符串数组空间
int?n;????//记录字符串长度
public:
Strings(char*str);??//构造函数,利用str字符串长度初始化n,
????????????????????//利用str字符串初始化s所指的字符串空间
Strings(Strings?str);????????//拷贝构造函数
Strings?Give(Strings?str);??//实现str赋值给*this的功能
????Strings?Uion(Strings?str);???//实现*this和str中的字符串合并的
?????????????????????//功能,把合并结果存入临时对象并返回
int?Lenth()?{return?n;}???????//返回字符串长度
void?Print()?{cout<<s<<endl;}?//输出字符串
};

7.?根据下面类中Give函数的原型和注释写出它的类外定义。(﹡﹡﹡)
class?Strings?{
char?*s;??//指向动态分配的字符串数组空间
int?n;????//记录字符串长度
public:
Strings(char*str);??//构造函数,利用str字符串长度初始化n,
????????????????????//利用str字符串初始化s所指的字符串空间
Strings(Strings?str);??//拷贝构造函数
Strings?Give(Strings?str);??//实现str赋值给*this的功能并返回*this
????Strings?Uion(Strings?str);??//实现*this和str中的字符串合并的
?????????????????????//功能,把合并结果存入临时对象并返回
int?Lenth()?{return?n;}??//返回字符串长度
void?Print()?{cout<<s<<endl;}??//输出字符串
};

8.?根据下面类中Uion函数的原型和注释写出它的类外定义。(﹡﹡﹡)
class?Strings?{
char?*s;??//指向动态分配的字符串数组空间
int?n;????//记录字符串长度
public:
Strings(char*str);??//构造函数,利用str字符串长度初始化n,
????????????????????//利用str字符串初始化s所指的字符串空间
Strings(Strings?str);??//拷贝构造函数
Strings?Give(Strings?str);??//实现str赋值给*this的功能并返回*this
Strings?Uion(Strings?str);???//实现*this和str中的字符串连接的功能,
??????????????????????????????//把连接结果存入临时对象并返回
int?Lenth()?{return?n;}??//返回字符串长度
void?Print()?{cout<<s<<endl;}??//输出字符串
};

第五章  静态成员与友元
单项选择题:
1.一个类的静态数据成员所表示属性 (   )。
A. 是类的或对象的属性   B. 只是对象的属性  C. 只是类的属性          D. 类和友元的属性
2.类的静态成员的访问控制(   )。
A. 只允许被定义为private
B. 只允许被定义为private或protected
C. 只允许被定义为public
D. 可允许被定义为private、protected或public
3.静态成员函数对类的数据成员访问(    )。
A. 是不允许的                 B. 只允许是静态数据成员
C. 只允许是非静态数据成员     D. 可允许是静态数据成员或非静态数据成员
4.被非静态成员函数访问的类的数据成员(  )。
A. 可以是非静态数据成员或静态数据成员    B. 不可能是类的静态数据成员
C. 只能是类的非静态数据成员              D. 只能是类的静态数据成员
5.静态数据成员的初始化是在(    )中进行的。
A. 构造函数          B. 任何成员函数    C. 所属类          D. 全局区
6.当将一个类A或函数f()说明为另一个类B的友元后,类A或函数f()能够直接访问类B的(    )。
A. 只能是公有成员                              B. 只能是保护成员
C. 只能是除私有成员之外的任何成员              D. 具有任何权限的成员
7.引入友元的主要目的是为了(    )。
A. 增强数据安全性                                     B. 提高程序的可靠性
C. 提高程序的效率和灵活性                             D. 保证类的封装性
8.一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明(    )。
A. 需加上类域的限定                                    B. 不需加上类域的限定
C. 类域的限定可加可不加                                D. 不需要任何限定
9.一个类的友元不是该类的成员,与该类的关系密切,所以它(    )。
A. 有this指针,有默认操作的对象
B. 没有this指针,可以有默认操作的对象
C. 有this指针,不能执行默认操作
D. 没有this指针,也就没有默认操作的对象

填空题:
1.?静态成员函数????(  )访问类的静态数据成员,?(  )访问类的非静态数据成员。
2.?静态数据成员必须在所有函数的定义体外进行(  )。
3.?一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明必须在函数名前加上?(  )?的限定。


简答题:
简述静态数据成员的主要应用。

2. 简述静态成员函数与一般成员函数的主要差别。

程序填空题:
?1.?一种类定义如下:
class?Goods
{
??private:
????char?gd_name[20];???????????//商品名称
????int?weight;?????????????????//商品重量
????static?int?totalweight;?????//同类商品总重量
??public:
Goods?(char*str,int?w){?????//构造函数
????strcpy(gd_name,str);
????weight=w;
????totalweight+=weight;
}
????~?Goods?(){totalweight?-=?weight;}?
????char*?GetN(){___(1)___;}??//返回商品名称
????int?GetW(){return?weight;}
___(2)___??GetTotal_Weight()?{??//定义静态成员函数返回总重量
????___(3)___;
}
}

2.
class?Point
{
??private:
????int?x,?y;
??public:
????Point(){x=y=0;}
????Point(int?x0,int?y0)?{x=x0;y=y0;}
????int?GetX()?{?return?x;?}
????int?GetY()?{?return?y;?}
????void?Print(){cout<<"oint("<<x<<","<<y<<")"<<endl;}
????___(1)___;??//友元函数声明
????___(2)___;??//友元函数声明
};

Point?operator+(Point?pt,int?dd)?
????//加号操作符重载函数,实现Point类对象与整数加法
{
??Point?temp=pt;
??temp.x+=dd;
??temp.y+=dd;
??return?temp;
}

Point?operator+(Point?pt1,Point?pt2)?
????//加号操作符重载函数,实现两个Point类对象的加法
{
??Point?temp=pt1;
??temp.x+=pt2.x;
??___(3)___;
??return?temp;
}

写出程序的执行结果:
1.请写出下列程序的运行结果。
程序:# include <iostream.h>
      void fun ()
      {
         static int i=25;
          i++ ;
          cout<< “i=”<<i<<endl;
       }
       void main ()
       {
          for (int j=0;j<2;j++)
             fun ();
       }

程序设计与分析题:
1. 程序:(﹡﹡﹡)
# include <iostream.h>   //(1)
# include <math.h>      //(2)
class point {            //(3)
     private:           //(4)
         float X,Y;     //(5)
     public:           //(6)
         point (float xi, float yi ) {X=xi ,Y=yi; }       //(7)
         float GetX() {return X}                   // (8)
         float GetY() {return Y}                   // (9)
         friend float distance (point & a ,point & b);    // (10)
};                                              //(11)
void main ()                                      //(12)
{                                               
         point pl (3.5,5.5), p2 (4.5,6.5);              //(13)
         float d = distance (p1, p2);                 //(14)
         cout << “The distance is ” << d;             //(15)
}
float distance (point & a ,point & b)                   //(16)
{
        float dx = a.X – b.X;                       //(17)
        float dy = a.Y – b.Y;                       // (18)
        return sqrt ( dx * dx + dy * dy );             // (19)
}
问题:1) 第(10)行的作用,有什么特点?
2)如果把它改写成这个类的成员函数,应该怎样改?

2. 下列程序段中,A_class的成员函数Variance()可求出两数的平方差,请改写该程序段,把Variance()函数从A_class类中分离出来,用友元函数来实现该函数的功能。(﹡﹡﹡)
class?A_class?{
??private:
????int?x,y,t;?
??public:
????A_class(int?i,int?j):x(i),y(j)?{
??????if(y>x){t=x;x=y;y=t;}
????}
??int?Variance(){return?x*x-y*y;}?
??//其它函数从略
};
void?main()?{
??A_class?A_obj(3,5);
??cout<<"Result:"<<A_obj.Variance()<<endl;
}

3.?下面给出了矩阵类Matrix定义。为了求两个矩阵对象的乘积,需要定义一个Matrix的友元函数Multiply()。请按照友元函数Multiply()的声明编写出该函数的定义。(﹡﹡﹡)
class?Matrix?{
??public:
Matrix(int?row,int?col);???//构造一个具有row行col列的矩阵
????~Matrix()?{delete?[]mem;} ???//析构函数
friend?bool?Multiply(Matrix?m1,?Matrix?m2,?Matrix?m3);?
???????????//定义Multiply()为友元函数,该函数把m1×m2的值赋给m3
//其他成员函数从略
??private:
int?*mem; ?????????????????//动态申请矩阵空间
const?int?rows,cols; ?????????//矩阵的行数和列数
};
Matrix::Matrix(int?row,int?col):rows(row),cols(col)
{
????mem?=?new?int[row*col];
}

bool?Multiply(Matrix?m1,?Matrix?m2,?Matrix?m3)
{
//确定矩阵是否能够进行相乘
??if(m1.rows?!=?m3.rows?||m2.cols?!=?m3.cols?||?m1.cols?!=?m2.rows)???return?false;
//定义sum变量,用于计算乘积矩阵m3中每个元素的值
??int?sum;
//请在下面编写剩余部分
}


第六章 继承
单项选择题:
1.在C++中,定义虚函数的关键字是(      )。
A.virtual    B.protected    C.operator    D.  this
2.从一个基类派生出的各个类的对象之间(    )。
A. 共享所有数据成员,每个对象还包含基类的所有属性
B. 共享部分数据成员,每个对象还包含基类的所有属性
C. 不共享任何数据成员,但每个对象还包含基类的所有属性
D. 共享部分数据成员和函数成员
3.如果是类B在类A的基础上构造,那么,就称(   )。
A. 类A为基类或父类,类B为超类或子类
B. 类A为基类、父类或超类,类B为派生类或子类
C. 类A为派生类,类B为基类
D. 类A为派生类或子类,类B为基类、父类或超类
4.C++的继承性允许派生类继承基类的(   )。
A. 部分特性,并允许增加新的特性或重定义基类的特性
B. 部分特性,但不允许增加新的特性或重定义基类的特性
C. 所有特性,并允许增加新的特性或重定义基类的特性
D. 所有特性,但不允许增加新的特性或重定义基类的特性
5.派生类的成员函数可以直接访问基类的(   )成员。
A. 所有         B. 公有和保护         C. 保护和私有         D. 私有
6.对于公有继承,基类的公有和保护成员在派生类中将(   )成员。
A. 全部变成公有                  B. 全部变成保护
C. 全部变成私有                  D. 仍然相应保持为公有和保护
7.对于公有继承,基类中的私有成员在派生类中将 (   )。
A. 能够直接使用成员名访问        B. 能够通过成员运算符访问
C. 仍然是基类的私有成员          D. 变为派生类的私有成员
8.当保护继承时,基类的(    )在派生类中成为保护成员,在类作用域外不能够通过派生类的对象来直接访问该成员。
A. 任何成员                      B.公有成员和保护成员
C. 保护成员和私有成员            D.私有成员
9.在定义一个派生类时,若不使用保留字显式地规定采用何种继承方式,则默认为(   )方式。
A. 私有继承     B. 非私有继承   C. 保护继承     D. 公有继承
10.建立包含有类对象成员的派生类对象时,自动调用构造函数的执行顺序依次为(    )的构造函数。
A. 自己所属类、对象成员所属类、基类   B. 对象成员所属类、基类、自己所属类
C. 基类、对象成员所属类、自己所属类   D. 基类、自己所属类、对象成员所属类
11.当派生类中有和基类一样名字的成员时,一般来说,(  )。
A. 将产生二义性              B. 派生类的同名成员将覆盖基类的成员
C. 是不能允许的              D. 基类的同名成员将覆盖派生类的成员
12.C++中的虚基类机制可以保证:(  )。
A. 限定基类只通过一条路径派生出派生类
B. 允许基类通过多条路径派生出派生类,派生类也就能多次继承该基类
C. 当一个类多次间接从基类派生以后,派生类对象能保留多份间接基类的成员
D. 当一个类多次间接从基类派生以后,其基类只被一次继承
13.下列对派生类的描述中错误的说法是:(    )。
A. 派生类至少有一个基类
B. 派生类可作为另一个派生类的基类
C. 派生类除了包含它直接定义的成员外,还包含其基类的成员
D. 派生类所继承的基类成员的访问权限保持不变
14.派生类的对象对其基类中(    )可直接访问。
A. 公有继承的公有成员   B. 公有继承的私有成员  C. 公有继承的保护成员   D. 私有继承的公有成员

填空题:
1.?在一个或若干个类的基础上构造一个新类,被称为( 继承(派生) )。
2.?派生类的成员函数可以直接访问基类的?( 公有和保护 )成员,不能直接访问基类的??( 私有 )成员。
3.?当保护继承时,基类的( 公有和保护 )?成员在派生类中成为保护成员,派生类对象不能直接访问基类的?( 任何 )成员。
4.?在定义一个派生类时,使用( private )关键字或者不显式地使用它则表示为( 私有 )继承。
5.?若多个基类及其派生类中都定义了同名函数成员,要访问相应函数时,就需要在函数名前加上( 类名 )和类区分符。??
6.?若要保证一个公共的基类在派生类中只产生一个基类子对象,则必须都以( 虚基类 )的方式直接继承它。
7.?引进虚基类的根本目的是为了消除( 二义性 )。
8.?在每个成员函数中,隐含的第一个参数的参数名为( this )  。

简答题:
1. 类的派生方式共有几种,基类成员权限在派生类中的权限怎样变化?
程序设计与分析题:
1. 已知类定义如下,其中Shape为基类,Circle和Rectangle分别Shape的直接派生类,Square为Rectangle的直接派生类和Shape的间接派生类。请模仿Circle类,写出Rectangle类的所有成员函数。(﹡﹡﹡)
/******************文件shape.h*************************/
const?float?PI=3.14159f;??//定义圆周率常量

class?Shape???//几何图形抽象类
{
??public:
????virtual?float?GetPerimeter()=0;?????//纯虚函数,计算周长
????virtual?float?GetAre()=0; ????????//纯虚函数,计算面积
};

class?Circle:?public?Shape????//圆类
{
??public:
Circle(float?rad):rad(rad){}
~Circle(){}
????float?GetPerimeter()?{return?2*PI*rad;}???//计算圆形周长
????float?GetAre()?{return?PI*rad?*rad;} ??????//计算圆形面积
??private:
????float?rad;??//圆的半径
};

class?Rectangle:?public?Shape????//矩形类
{
??public:??//在下面编写每个成员函数


??private:
????float?length,?width;??//矩形的长和宽
};

class?Square:?public?Rectangle???//正方形类
{
??public:
Square(float?len):?Rectangle(len,len){}
~Square(){}
};



2.?已知类定义如下,其中Shape为基类,Circle和Rectangle分别Shape的直接派生类,Square为Rectangle的直接派生类和Shape的间接派生类。请模仿Rectangle类,写出Circle类的所有成员函数。(﹡﹡﹡)
/******************文件shape.h*************************/
const?float?PI=3.14159f;??//定义圆周率常量

class?Shape???//几何图形抽象类
{
??public:
????virtual?float?GetPerimeter()=0;?????//纯虚函数,计算周长
????virtual?float?GetAre()=0; ????????//纯虚函数,计算面积
};

class?Rectangle:?public?Shape????//矩形类
{
??public:
Rectangle?(float?len,float?wid):length(len),width(wid){}
~Rectangle?(){}
????float?GetPerimeter()?{return?2*(length+width);}???//计算矩形周长
????float?GetAre()?{return?length*width;} ????????//计算矩形面积
??private:
????float?length,?width;??//矩形的长和宽
};

class?Circle:?public?Shape????//圆类
{
??public:??//在下面编写每个成员函数


??private:
????float?rad;??//圆的半径
};

class?Square:?public?Rectangle???//正方形类
{
public:
Square(float?len):?Rectangle(len,len){}
~Square(){}
};


第七章 多重继承
简答题:
1. 简述多继承中构造函数被调用顺序。

程序填空题:
1.?在下面一段类定义中,?Derived类是由直接基类Base?1和Base?2所派生的,Derived类包含有两个间接基类BaseBase,在初始化函数Init中,需要把x1和x2的值分别赋给属于基类Base1的x成员和属于基类Base2的x成员。
class?BaseBase?{
??protected:
????int?x;
??public:
????BaseBase(){?x?=?1;}
};

class?Base1:?public?BaseBase?{
??public:
????Base1(){}
};

class?Base2:?public?BaseBase?{
??public:
????Base2(){}
};

class?Derived:?___(1)___
{
??public:
??Derived()?{}
??void?Init(int?x1,?int?x2)?{
??___(2)___;?___(3)___;
??}
??
??void?output()?{cout<<Base1::x<<?<<Base2::x<<endl;}
};


2.?在下面一段类定义中,?Derived类公有继承了基类Base。需要填充的函数由注释内容给出了功能。
class?Base
{
??private:
????int?mem1,mem2;????//基类的数据成员
??public:
??Base(int?m1,int?m2)?{?
mem1=m1;?mem2=m2;
??}
??void?output(){cout<<mem1<<?<<mem2<<?;}
?????//...
};

class?Derived:?public?Base
{
??private:
????int?mem3;?????????//派生类本身的数据成员
??public:
??//构造函数,由m1和m2分别初始化mem1和mem2,由m3初始化mem3
????Derived(int?m1,int?m2,?int?m3);?
??//输出mem1,mem2和mem3数据成员的值
????void?output(){?
___(1)___;?cout<<mem3<<endl;
}
//...
};

Derived:erived(int?m1,int?m2,?int?m3):?___(2)___?{___(3)___;}


3.?在下面一段类的定义中,需要填充的函数由注释内容给出了功能。
class?Point?//定义坐标点类
{
??public:
????int?x,y;???//点的横坐标和纵坐标
????Point(){x=0;y=0;}
????Point(int?x0,int?y0)?{x=x0;?y=y0;}?
????int?X(){return?x;}
????int?Y(){return?y;}
????void?PrintP(){cout<<"oint"<<x<<","<<y<<")"<<endl;}
};

class?Line:?public?Point???//利用坐标点类定义直线类
{
??private:
????class?Point?pt1,pt2;???//直线的两个端点
??public:
Line(Point?pts,?Point?pte);??//构造函数,分别用参数初始化对应的端点
????double?Dx(){return?pt2.x-pt1.x;}
????double?Dy(){return?pt2.y-pt1.y;}
????double?Length(){?//计算直线的长度
return?sqrt(___(1)___);
};
????void?PrintL();??//输出直线的两个端点和直线长度
};

Line:ine(Point?pts,?Point?pte)?___(2)___?
void?Line:rintL()
{
??cout<<"1st?";
??pt1.PrintP();
??cout<<"2nd?";
??pt2.PrintP();
??cout<<"The?Length?of?Line:?"<<___(3)___?<<endl;
}
答案:(1) Dx()*Dx()+Dy()*Dy()
(2) {pt1=pts;pt2=pte;} (或 :pt1(pts),pt2(pte){})
(3) Length()

4.?在下面一段类的定义中,自行车类的虚基类为车辆类,机动车类的虚基类也为车辆类,摩托车类的基类为自行车类和机动车类,类之间均为公有继承。
class?vehicle??//车辆类
{
??private:
????int?MaxSpeed;??//最大车速
????int?Weight;????//车重
??public:
????vehicle(){MaxSpeed=0;?Weight=0;};
????virtual?void?Run()?{cout<<"A?vehicle?is?running!"<<endl;}
};

class?bicycle?:?___(1)___??//自行车类
{?
??private:
????int?Height;??//车高
??public:
????bicycle(){};
????void?Run()?{cout<<"A?bicycle?is?running!"<<endl;}
};

class?motorcar?:?___(2)___??//机动车类
{?
??private:
????int?SeatNum;??//乘人数
??public:
????motorcar(){};
????void?Run()?{cout?<<?"A?motorcar?is?running!"?<<?endl;?}
};
class?motorcycle:?___(3)___??//摩托车类
{?
??public:
????motorcycle?(){};
????void?Run()?{cout<<"A?motorcycle?is?running!"<<endl;}
};


写出程序的执行结果:
1. 请写出下面程序的运行结果:
程序:#include<iostream.h>
class OBJ1{public:  OBJ1(){ cout <<"OBJ1\n"; }};
class OBJ2{public:  OBJ2(){ cout <<"OBJ2\n"; }};
class Base1{public:  Base1(){ cout <<"Base1\n"; }};
class Base2{public:  Base2(){ cout <<"Base2\n"; }};
class Base3{public:  Base3(){ cout <<"Base3\n"; }};
class Base4{public:  Base4(){ cout <<"Base4\n"; }};
class Derived :public Base1, virtual public Base2,
public Base3, virtual public Base4{
public:  Derived() :Base4(), Base3(), Base2(), Base1(), obj2(), obj1()  {
    cout <<"Derived ok.\n";  }
protected:  OBJ1 obj1;  OBJ2 obj2;};
void main(){  Derived aa;  cout <<"This is ok.\n";}


第八章  运算符重载
单项选择题:
1.在成员函数中进行双目运算符重载时,其参数表中应带有(    )个参数。
A. 0      B. 1      C. 2      D. 3
2.双目运算符重载为普通函数时,其参数表中应带有(    )个参数。
A. 0      B. 1      C. 2      D. 3
3.如果表达式a+b中的“+”是作为成员函数重载的运算符,若采用运算符函数调用格式,则可表示为(    )。
A. a.operator+(b)          B. b.operator+(a)    C. operator+(a,b)            D. operator(a+b)
4.如果表达式a==b中的“==”是作为普通函数重载的运算符,若采用运算符函数调用格式,则可表示为(    )。
A. a.operator==(b)           B. b.operator==(a)   C. operator==(a,b)          D. operator==(b,a)
5.如果表达式a++中的“++”是作为普通函数重载的运算符,若采用运算符函数调用格式,则可表示为(    )。
A. a.operator++()           B. operator++(a)    C. operator++(a,1)           D. operator++(1,a)
6.如果表达式++a中的“++”是作为成员函数重载的运算符,若采用运算符函数调用格式,则可表
示为(    )。
A. a.operator++(1)            B. operator++(a)    C. operator++(a,1)           D. a.operator++()
7.关于运算符重载,下列说法正确的是(   )。
A. 重载时,运算符的优先级可以改变。   B. 重载时,运算符的结合性可以改变。
C. 重载时,运算符的功能可以改变。     D. 重载时,运算符的操作数个数可以改变。
8.关于运算符重载,下列说法正确的是(   )。
A. 所有的运算符都可以重载。
B. 通过重载,可以使运算符应用于自定义的数据类型。
C. 通过重载,可以创造原来没有的运算符。
D. 通过重载,可以改变运算符的优先级。
9.一个程序中数组a和变量k定义为“int a[5][10],k;”,且程序中包含有语句“a(2,5)=++k*3;”,则此语句中肯定属于重载操作符的是(  )。
A. ( )     B. =      C. ++      D. *
10.假定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);
11.假定M是一个类名,且M中重载了操作符=,可以实现M对象间的连续赋值,如“m1=m2=m3;”。重载操作符=的函数原型最好是(  )。
A. int operaotor=(M);          B.  int operator=(M&);  C. M operator=(M&);          D.  M& operator=(M);
12.下面是重载双目运算符+的普通函数原形,其中最符合+原来含义的是(   )。
A. Value operator+(Value, Value);           B. Value operator+(Value,int);
C. Value &operator+(Value, Value);          D. Value &operator+(Value&, Value&);
13.下面是重载双目运算符-的成员函数原形,其中最符合-原来含义的是(   )。
A. Value Value:perator-(Value);      B. Value Value:perator-(int);
C. Value& Value:perator-(Value);    D. Value& Value:perator-(Value&);
14.在重载一运算符时,若运算符函数的形参表中没有参数,则不可能的情况是(   )。
A. 该运算符是一个单目运算符。    B. 该运算符函数有一个隐含的参数this。
C. 该运算符函数是类的成员函数。  D. 该运算符函数是类的友元函数。
15.关于插入运算符<<的重载,下列说法不正确的是(   )。
A. 运算符函数的返回值类型是ostream & 。  B. 重载的运算符必须定义为类的成员函数。
C. 运算符函数的第一个参数的类型是ostream & 。   D. 运算符函数有两个参数。
16.在重载一个运算符时,其参数表中没有任何参数,这表明该运算符是(    )。
A. 作为友元函数重载的1元运算符         B. 作为成员函数重载的1元运算符
C. 作为友元函数重载的2元运算符         D. 作为成员函数重载的2元运算符

填空题:
1.?重载运算符时,该运算符的(  )、结合性以及操作符的个数不允许改变。
2.?一个单目运算符作为类的成员函数重载时有(  )个参数;如果作为独立函数重载,则有(  )  个参数。
3.?一个双单目运算符作为类的成员函数重载时有(   )  个参数;如果作为独立函数重载,则有(  )  个参数。
4.?除了(  )运算符外,其他重载的运算符都可以被派生类继承。
5.?作为类的成员函数重载一个运算符时,参数表中只有一个参数,说明该运算符有(  )个操作数。
6.?在重载一个单目运算符时,参数表中没有参数,说明该运算符函数只能是类的(  )  。
7.?重载插入运算符<<时,其运算符函数的返回值类型应当是(  )。
8.?重载抽取运算符>>时,其运算符函数的返回值类型应当是(  )。
9.?重载插入运算符<<或抽取运算符>>时,其运算符函数的参数有(  )个。
10.?重载插入运算符<<或抽取运算符>>时,其运算符函数不能被定义为类的(  )函数。
11.?类型转换函数没有(  )类型,而且参数表为(  )  。

程序填空题:
1.?已知一维数组类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<<"下标越界!";?exit(1);}
????return?___(3)___;
}

2.?已知一维数组类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<n;?i++)?___(3)___;
}

3.?下面是一维数组类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<<"下标越界!";?exit(1);}
????return?___(3)___;
}

写出程序的执行结果:
1. 请写出下面程序的运行结果:
程序:
#include <iostream.h>     
#include <iomanip.h>//控制符是在该头文件中定义的对象
void fn(float interest, float amount){
  cout <<"RMB amount = " <<setprecision(2) <<amount;
  cout <<"\nthe interest = " <<setprecision(4) <<interest <<endl;}
void main(){
  float f1 =29.41560067;
  float f2 =12.567188;
  fn(f1,f2);}

程序设计与分析题:
1.程序:
#include <iostream.h>
class complex{  private:   int real ; int imag ;
public: complex(float r=0,float i=0);
complex operator + (complex&  c);
complex operator - (complex&  c);
complex operator - ( );  void print( );};
complex::complex(float r=0,float i=0){real=r; imag=i}
complex complex:perator + (complex&  c){
float r= real + c.real ;float i= imag + c.imag ;return  complex(r ,i );}
complex complex::operator - (complex&  c){
float r= real - c.real ;float i= imag - c.imag ;return  complex(r ,i );}
complex operator - ( ){return complex(-real,-img);}
void complex::print( ){cout<<"("<<real<<","<<imag<<")"<<endl;}
void main(){complex x(2.5,3.8),y(4.7,5.4),z;
z=x+y; z.print();z=x-y; z.print();z=-x;  z.print();}
问题:本例是使用类的成员函数来实现复数类的运算符重载,请在不改变主函数的情况下,采用友元的形式来实现复数类的运算符重载。写出相应的程序。



第九章 模版
单项选择题:
1.以下关于函数模板叙述正确的是(    )。
A. 函数模板也是一个具体类型的函数
B. 函数模板的类型参数与函数的参数是同一个概念
C. 通过使用不同的类型参数,函数模板可以生成不同类型的函数
D. 用函数模板定义的函数没有类型

填空题:
1.?定义一个函数模板要用到的第一个修饰符是( template )。
2.?在函数模板的参数中,用class修饰的参数称为( 虚拟类型(或类型) )参数。
3.?如果一个函数直接或间接地调用自身,这样的调用称为( 递归 )调用。
4.?已知int?cubin(int?n){return?n*n*n;}和double?cubin(double?n){return?n*n*n;}是一个函数模板的两个实例,假定类型参数用T表示,则该函数模板的定义是( template<class T>  T cubin(T n){return n*n*n ; }  )。

写出程序的执行结果:
1. 请写出下面程序的运行结果:
程序:
  # include “iostream.h”                                       
  template < class T>                                             
  T  max (T x ,T y)                                            
  {  return (x>y)?(x): (y);                                       
  }
  void main ( )
  {
     int x=3 ,y =4;                                               
     double a =1.1 ,b =3.4;                                       
     cout << max(x ,y)<<endl;                                    
     cout << max(a,b)<<endl;                                      
}

2.请写出下面程序的运行结果:
程序:
#include <iostream.h>
void swap(int &x,int &y);
void main(){
  int x=5, y=6;
  cout <<"before swap, x:" <<x <<" ,y:" <<y <<endl;
  swap(x,y);
  cout <<"after swap, x:" <<x <<" ,y:" <<y <<endl;}
void swap(int &rx,int &ry){
  int temp=rx;  rx=ry;  ry=temp;}



Y.X
发表于 2017-12-1 14:40:31 | 显示全部楼层
发表于 2023-4-12 17:16:39 | 显示全部楼层
快速回复 返回顶部 返回列表