文档库 最新最全的文档下载
当前位置:文档库 › c++重点难点复习题及答案

c++重点难点复习题及答案

c++重点难点复习题及答案
c++重点难点复习题及答案

1、数据共享与保护

一、选择题:

1、在下面存储类中, ( C ) 对象的可见性与生存期不一致。

A. 外部类

B. 自动类

C. 内部静态类

D. 寄存器类

2、在下面存储类中,(A)的对象不是局部变量。

A. 外部静态类

B. 自动类

C. 函数形参

D. 寄存器类

3、关于局部变量,下面说法正确的是( C )。

A. 定义该变量的程序文件中的函数都可以访问

B. 定义该变量的函数中的定义处以下的任何语句都可以访问

C. 定义该变量的复合语句中的定义处以下的任何语句都可以访问

D. 定义该变量的函数中的定义处以上的任何语句都可以访问

4、一个类的静态数据成员所表示属性 ( C )。

A. 是类的或对象的属性

B. 只是对象的属性

C. 只是类的属性

D. 类和友元的属性

5、类的静态成员的访问控制( D)。

A. 只允许被定义为private

B. 只允许被定义为private或protected

C. 只允许被定义为public

D. 可允许被定义为private、protected或public

6、静态成员函数对类的数据成员访问(B)。

A. 是不允许的

B. 只允许是静态数据成员

C. 只允许是非静态数据成员

D. 可允许是静态数据成员或非静态数据成员

7、被非静态成员函数访问的类的数据成员( A )。

A. 可以是非静态数据成员或静态数据成员

B. 不可能是类的静态数据成员

C. 只能是类的非静态数据成员

D. 只能是类的静态数据成员

8、静态数据成员的初始化是在(D)中进行的。

A. 构造函数

B. 任何成员函数

C. 所属类

D. 全局区

9、当将一个类A或函数f()说明为另一个类B的友元后,类A或函数f()能够直接访问类B的( D )。

A. 只能是公有成员

B. 只能是保护成员

C. 只能是除私有成员之外的任何成员

D. 具有任何权限的成员

10、引入友元的主要目的是为了( C )。

A. 增强数据安全性

B. 提高程序的可靠性

C. 提高程序的效率和灵活性

D. 保证类的封装性

11、一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明( A )。

A. 需加上类域的限定

B. 不需加上类域的限定

C. 类域的限定可加可不加

D. 不需要任何限定

二、判断题

1、类的静态数据成员需要在定义每个类的对象时进行初始化。F

2、当将一个类S定义为另一个类A的友元类时,类S的所有成员函数都可以直

接访问类A的所有成员。T

3、静态数据成员必须在类外定义和初始化。T

4、静态成员函数可以引用属于该类的任何函数成员F。

5、友元函数是在类声明中由关键字friend修饰说明的类的成员函数。F

6、友元函数访问对象中的成员可以不通过对象名F

三、填空题:

1、若“double x=100;”是文件F1.CPP中的一个全局变量定义语句,若文件F2.CPP中的某个函数需要访问此x , 则应在文件F2.CPP中添加对x的声明语句为Extern double x;

2、如果一个函数定义中使用了static修饰,则该函数不允许被其它文件中的函数调用。

3、定义外部变量时,不用存储类说明符Extern,而声明外部变量时用它。

4、调用系统函数时,要先使用#include命令包含该系统函数的原型语句所在的头文件。

5、C++程序运行时的内存空间可以分成全局数据区,堆区,栈区和代码区。

6、局部变量具有局部生存期,存放在内存的栈区中。

7、对类中对象成员的初始化是通过在构造函数中给出的初始化表来实现的。

8、对类中常量成员的初始化是通过在构造函数中给出的初始化表来实现的。

9、对类中引用成员的初始化只能通过在构造函数中给出的初始化表来实现。

10、对类中一般数据成员的初始化既可以通过在构造函数中给出的初始化表来实现,也可以通过构造函数中的函数体来实现。

11、假定要把aa定义为AB类中的一个常量整数型数据成员,则定义语句const int aa。

12、假定要把aa定义为AB类中的一个引用整数型数据成员,则定义语句为int &aa。

13、假定AB类中只包含一个整型数据成员a,并且它是一个常量成员,若利用参数aa对其进行初始化,则该类的构造函数的定义为AB (int aa){a=aa;}。

14、假定AB类中只包含一个整型数据成员a,并且它是一个引用成员,若利用引用参数aa对其进行初始化,则该类的构造函数的定义为AB(int &aa){a=aa;}。

15、静态成员函数能够直接访问类的静态数据成员,只能通过对象名访问类的非静态数据成员。

16、静态数据成员必须在所有函数的定义体外进行初始化。

17、一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明必须在函数名前加上类域的限定。

四、修改程序题:

下列程序段中,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:"<

修改后的源程序:

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;}

}

friend int Variance();

//其它函数从略

};

int variance (){

return x*x-y*y;

}

void main() {

A_class A_obj(3,5);

cout<<"Result:"<

2、数组、指针与字符串

一、

1、在下面的一维数组定义中,哪一个有语法错误。(C)

A. int a[]={1,2,3};

B. int a[10]={0};

C. int a[];

D. int a[5];

2、在下面的字符数组定义中,哪一个有语法错误。(D)。

A. char a[20]=”abcdefg”;

B. char a[]=”x+y=55.”;

C. char a[15];

D. char a[10]=’5’;

3、在下面的二维数组定义中,正确的是( C )。

A. int a[5][];

B. int a[][5];

C. int a[][3]={{1,3,5},{2}};

D. int a[](10);

4、假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[1][2]的值为(C)。

A. 2

B. 4

C. 6

D. 8

5、假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[2][1]的值为(A)。

A. 0

B. 4

C. 8

D. 6

6、若定义了函数 double *function(), 则函数function的返回值为(B)。

A. 实数型

B.实数的地址

C.指向函数的指针

D.函数的地址

7、以下函数的返回结果是( A )。

int function(char *x) {

char *p=x; while(*p++); return(p-x-1);

}

A. 求字符串的长度

B.将字符串x连接到字符串p后面

C. 将字符串x复制到字符串p中

D.将字符串x反向存放

8、设有如下函数定义

int f(char *s) {

char *p=s;

while(*p!=’\0’) p++;

return(p-s);

}

在主函数中用cout<

A. 3

B. 4

C. 5

D. 6

9、假定变量m定义为“int m=7;”,则定义变量p的正确语句为( B )。

A. int p=&m;

B. int *p=&m;

C. int &p=*m;

D. int *p=m;

10、变量s的定义为“char *s=”Hello world!”;”,要使变量p指向s所指向的同一个字符串,则应选取( A)。

A. char *p=s;

B. char *p=&s;

C. char *p;p=*s;

D. char *p; p=&s

11、关于void 指针,下列说法正确的是( C )。

A. void 指针就是未指向任何数据的指针

B. void 指针就是已定义而未初始化的指针

C. 指向任何类型数据的指针可直接赋值给一个void 指针

D. void 指针值可直接赋给一个非void 指针

12、假定一条定义语句为“int a[10], x, *pa=a;”,若要把数组a中下标为3的元素值赋给x,则不正确的语句为( D)。

A. x=pa[3];

B. x=*(a+3);

C. x=a[3];

D. x=*pa+3;

13、假定有定义“int b[10]; int *pb;”,则不正确的赋值语句为(D)。

A. pb=b;

B. pb=&b[0];

C. *pb=new int;

D.

pb=b[5];

14、假定p是具有double类型的指针变量,则表达式++p使p的值(以字节为

单位)增加( C )。

A. 1

B. 4

C. sizeof(double)

D. sizeof(p)

15、假定p指向的字符串为”string”,则cout<

A. string

B. ring

C. ing

D. i

16、假定p指向的字符串为”string”,若要输出这个字符串的地址值,则使用( D )。

A. cout<<*s;

B. cout<

C. cout<<&s;

D. cout<<(void *)s;

17、定义p并使p指向动态空间中的包含30个整数的数组所使用的定义语句为( A )。

A. int *p=new int[30];

B. int *p=new int(30);

C. int *p=new [30];

D. *p=new int[30];

18、假定p是具有int**类型的指针变量,则给p赋值的正确语句为( B )。

A. p=new int;

B. p=new int*;

C. p=new int**;

D. p=new int[10];

19、要使语句“p=new int[10][20];”能够正常执行,p应被事先定义为( D )。

A. int *p;

B. int **p;

C. int *p[20];

D. int(*p)[20];

20、假定变量a和pa定义为“double a[10], *pa=a;”,要将12.35赋值给a 中的下标为5的元素,不正确的语句是( D )。

A. pa[5]=12.35;

B. a[5]=12.35;

C. *(pa+5)=12.35;

D. *(a[0]+5)=12.35;

21、假定变量b和pb定义为“int b[10], *pb=b;”,要将24赋值给b[1]元素中,不正确的语句是(C)。

A. *(pb+1)=24;

B. *(b+1)=24;

C. *++b=24;

D.

*++pb=24;

22、假定指针变量p定义为“int *p=new int(100);”,要释放p所指向的动态内存,应使用语句(A)。

A. delete p;

B. delete *p;

C. delete &p;

D. delete []p;

23、假定指针变量p定义为“int *p=new int[30];”,要释放p所指向的动态内存,应使用语句(D)。

A. delete p;

B. delete *p;

C. delete &p;

D. delete []p;

24、当类中一个字符指针成员指向具有n个字节的存储空间时,它所能存储字符串的最大长度为( C )。

A. n

B. n+1

C. n-1

D. n-2

25、在一个用链表实现的队列类中,假定每个结点包含的值域用elem表示,包含的指针域用next表示,链队的队首指针用elemHead表示,队尾指针用elemTail表示,若链队非空,则进行插入时必须把新结点的地址赋给( D )。

A. elemHead

B. elemTail

C. elemHead->next和elemHead

D. elemTail->next和elemTail

26、在一个用链表实现的队列类中,假定每个结点包含的值域用elem表示,包含的指针域用next表示,链队的队首指针用elemHead表示,队尾指针用elemTail表示,若链队为空,则进行插入时必须把新结点的地址赋给( C )。

A. elemHead

B. elemTail

C. elemHead和elemTail

D. elemHead或elemTail

27、当类中的一个整型指针成员指向一块具有n*sizeof(int)大小的存储空间时,它最多能够存储( A )个整数。

A. n

B. n+1

C. n-1

D. 1

28、假定AB为一个类,则执行“AB *px=new AB[n];”语句时将( A )。

A. 动态分配一个数组

B. 动态分配一个对象

C. 静态分配一个数组

D. 静态分配一个对象

29、设px是指向一个类对象的指针变量,则执行“delete px;”语句时,将自动调用该类的( C )。

A. 无参构造函数

B. 带参构造函数

C. 析构函数

D. 拷贝构造函数

30、当一个类对象离开它的作用域时,系统自动调用该类的( D )。

A. 无参构造函数

B. 带参构造函数

C. 拷贝构造函数

D. 析构函数

31、假定一个类对象数组为A[n],当离开它定义的作用域时,系统自动调用该类析构函数的次数为( C )。

A. 0

B. 1

C. n

D. n-1

32、假定AB为一个类,则执行“AB a[10];”语句时调用该类无参构造函数的次数为( D )。

A. 0

B. 1

C. 9

D. 10

33、假定AB为一个类,则执行“AB *px=new AB[n];”语句时调用该类无参构造函数的次数为( A )。

A. n

B. n-1

C. 1

D. 0

34、假定AB为一个类,则执行“AB a, b(3), *p;”语句时共调用该类构造函数的次数为( A )。

A. 2

B. 3

C. 4

D. 5

35、假定AB为一个类,则执行“AB a(2), b[3], *p[4];”语句时共调用该类构造函数的次数为( B )。

A. 3

B. 4

C. 5

D. 9

36、假定AB为一个类,则执行“AB a, b(2), c[3], *p=&a;”语句时共调用该类无参构造函数的次数为( D )

A. 5

B. 6

C. 3

D. 4

37、假定AB为一个类,则执行“AB *p=new AB(1,2);”语句时共调用该类构造函数的次数为( B )。

A. 0

B. 1

C. 2

D. 3

38、假定AB为一个类,px为指向该类的一个含有n个对象的动态数组的指针,则执行“delete []px;”语句时共调用该类析构函数的次数为( C )。

A. 0

B. 1

C. n

D. n+1

二、填空题:

1、用于存储一个长度为n的字符串的字符数组的长度至少为_n+1_______。

2、若a是一个字符数组,则从键盘上向该数组输入一个字符串的表达式为_getline(cin,a);_________。

3、若a是一个字符数组,则向屏幕输出a中所存字符串的表达式为_cout<

4、一个二维字符数组a[10][20]能够存储__10______个字符串,每个字符串的长度至多为__19______。

5、对一个二维字符数组a进行初始化的数据为{”123”,”456”,”789”},则a[1]元素对应的字符串为__”456”________。

6、strlen(”apple”)的值为__5______,strcmp(”a”,”A”)的值为_1_______。

7、假定对数组a[]进行初始化的数据为{2,7,9,6,5,7,10},则a[2]和a[5]分别被初始化为__9______和___7_____。

8、假定对二维数组a[3][4]进行初始化的数据为{{3,5,6},{2,8},{7}},则a[1][1]和a[2][3]分别被初始化为___8____和___0_____。

9、若二维数组a有m列,设a[0][0]位于数组的第一个位置上,则计算任一元素a[i][j]在数组中位置序号的公式为_i*m+j+1__________。

10、

若有定义“double a[3][5];”,则a 数组中行下标和列下标的最大值分别为___2_____和___4_____。

11、一个指针类型的对象占用内存的___4_____个字节的存储空间。

12、一个指针指向一个数据对象,它保存着该数据对象的_地址_______,若数据对象为DataType类型,则相应的指针类型为___Datatype*_______。

13、若要把一个整型指针p转换为字符指针,则采用的强制转换表达式为_(char*)p_______。

14、假定一个数据对象为int*类型,则指向该对象的指针类型为_int **______。

15、假定p是一个指向整数对象的指针,则用__*P______表示该整数对象,用_____P___表示指针变量p的地址。

16、假定p是一个指针,则*p++运算首先访问__*p____,然后使p_的值增1。

17、假定p是一个指针,则(*p)++运算首先访问_*p__,然后使__*p______的值增1。

18、假定p所指对象的值为25,p+1所指对象的值为42,则*p++的值为__25______。

19、假定p所指对象的值为25,p+1所指对象的值为42,则*++p的值为_42_______。

20、假定p所指对象的值为25,p+1所指对象的值为42,则执行(*p)++运算后,p所指对象的值为___26_____。

21、假定p所指对象的值为25,p+1所指对象的值为42,则执行*(p++)或*p++运算后,p所指对象的值为___42_____。

22、假定a是一个一维指针数组,则a+i所指对象的地址比a大__4*i______字节。

23、假定a是一个一维数组,则a[i]的指针访问方式为__*(a+i)______。

24、假定a是一个一维数组,则a[i]对应的存储地址(以字节为单位)为__a+i*sizeof(a[i])__________。

25、一个数组的数组名实际上是指向该数组____首____元素的指针,并且在任何时候都不允许_ ___修改____它。

26、假定指向一维数组b[10]中元素b[4]的指针为p,则p+3所指向的元素为__b[7]_____,p-2所指向的元素为_b[2]_______。

27、若要定义整型指针p并初始指向x,则所使用的定义语句为

_int*p=&x_______。

28、若p指向x,则___*p_____与x的表示是等价的。

29、在一个二维数组int a[m][n]中,包含的一维元素a[i]的类型为__ int[n]______,访问a[i]时返回值的类型为__ int*______。

30、假定一个二维数组为c[5][8],则c[3]的值为二维元素c[3][0]________的地址,c[3]+2的值为二维元素_c[3][2]_______的地址。

31、假定p为指向二维数组int d[4][6]的指针,则p的类型为_int (*)[6]______。

32、假定a是一个二维数组,则a[i][j]的指针访问方式为__*(*(a+i)+j)__________。

33、执行int p=new int操作得到的一个动态分配的整型对象为__*p______。

34、执行int *p=new int[10]操作,使p指向动态分配的数组中下标为0的元素,该元素可表示为_*p______或__p[0]______。

35、执行char *p=new char(’a’)操作后,p所指向的数据对象的值为__a______。

36、执行new char[m][n]操作时的返回值的类型为__char(*)[n]______。

37、执行_delete_p______操作将释放由p所指向的动态分配的数据空间。

38、执行_delete[]p_______操作将释放由p所指向的动态分配的数组空间。

39、NULL是一个符号常量,通常作为空指针值,它的具体值为___0_____。

40、变量v定义为“double v=23.4;”,要使指针pv指向v,则定义pv的语句为___double *pv=&v___________。

41、已知语句“cout<

42、. 已知语句“cout<

43、指针变量pv和pc定义为“void *pv =”Hello, word!”; char *pc;”,要将pv值赋给pc,则正确的赋值语句是_ strcpy(pc,pv);pc=char(*)pv______________。

44、数组b定义为“int b[20][100];”,要使p[j][k] 与b[j][k] 等效,则指针p应定义为__int (*p)[100]=b ______________。

45、与结构成员访问表达式p->name等价的表达式是__(*p).name__________。

46、与结构成员访问表达式(*fp).score等价的表达式是__fp->score__________。

47、已知有定义“int x, a[]={5,7,9}, *pa=a;”,在执行“x=++*pa;”语句后,x的值是____6____。

48、已知有定义“int x, a[]={6,10,12}, *pa=a;”,在执行“x=*++pa;”语句后,*pa的值是_10_______。

49、已知有定义“int x, a[]={15,17,19}, *pa=a;”,在执行“x=*pa++;”后,*pa的值是__17______。

50、若采用p->abc(y)表达式调用一个成员函数,在成员函数中使用的__this_就代表了类外的p指针。

51、在一个用数组实现的队列类中,包含有两个数据成员,一个指明队首元素位置,另一个指明___队列长度_________。

52、在一个用数组实现的队列类中,包含有两个数据成员,一个指明队列长度,另一个指明___队首_______元素的位置。

53、在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则插入一个新元素的位置为___(first+length)MS_______。

54、在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,

队列长度为length,则删除一个元素后队首的位置为__(first+1)MS ________。

55、定义类动态对象数组时,其元素只能靠自动调用该类的__无参构造函数__________来进行初始化。

56、为了释放类对象中指针成员所指向的动态存储空间,则需要为该类定义____析构函数________。

57、假定AB为一个类,则执行“AB a[10];”语句时,系统自动调用该类构造函数的次数为__10______。

58、假定一个类对象数组为A[N],当离开它的作用域时,系统自动调用该类析构函数的次数为_N_______。

60、假定指针p指向一个动态分配的类对象,则当执行“delete p;”语句时,在释放p所指向的动态存储空间之前将自动调用该类的___析构函数_________。

61、假定AB为一个类,该类中含有一个指向动态数组空间的指针成员pa,则在该类的析构函数中应该包含有一条__delete[]pa;____________语句。

三、程序填空题:

1、采用指针访问方式从键盘给数组a[N]输入数据,然后对元素值重新按逆序存放并输出。

#include

const int N=8;

void main()

{

int a[N],*p,*q;

for(p=a; p>*p;

p=a;q=a+N-1;

while(p

int r=*p; *p=*q; *q=r;

p++; q++;

}

for(p=a;p

cout<<*p<<' ';

cout<

}

1、 (1) cin>>*p (2) p++ (或++p) (3) q-- (或--q)

2、假定有定义为“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++;

}

}

2、(1) i

3、已知一维数组类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

}

3、 (1) ARRAY:: (2) new int[n] (3) v[i]=a[i]

4、下面是一维数组类ARRAY的定义,ARRAY与普通一维数组区别是:(a)用()而不是[]进行下标访问,(2)下标从1而不是从0开始,(c)要对下标是否越界进行检查。

class {

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)___;

}

4、(1) int& ARRAY:: (2) n<1 || n>s (3) v[n-1] (或*(v+n-1))

5、已知一个类的定义如下:

#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个元素

};

该类中MaxA()函数的实现如下,请在标号位置补充适当的内容。

int _ __(1)_____

{

int x=a[0];

for(int i=1; i

if(a[i]>x) _ _(2)___;

___(3) ___;

}

5、(1) AA::MaxA() (2) x=a[i] (3) return x

6、已知一个类的定义如下:

#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

if(a[j]

a[k]=a[i];

___(3)___;

}

}

6、(1) i

7、已知一个类的定义如下:

#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 ___(1)___

{

int i,j;

for(i=1; i

int x=a[i];

for(j=i-1; j>=0; j--)

if(x

else ___(3)___;

a[j+1]=x;

}

}

7、(1) AA::InsertA() (2) a[j+1]=a[j] (3) break

8、已知一个类的定义如下:

#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 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

8、(1) x.SetA(a,6) (2) x.MaxA() (3) x.PrintA()

9、已知一个类的定义如下:

#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 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<

}

该程序运行结果为:

23 25 46 55 62 76 78 90

90

9、(1) AA x (2) m=x.MaxA() (3) x.SortA()

10、class A {

int a;

public:

A() {a=0;}

___(1)___{} //定义构造函数,用参数aa初始化数据成员a };

main() {

___(2)___; //定义类A的指针对象p

___(3)__; //用p指向动态对象并初始化为整数5

}

10、答案:(1) A(int aa):a(aa)

(2) A *p

11、class A {

char *a;

public:

___(1)___ //定义无参构造函数,使a的值为空

A(char *aa) {

a=___(2)___;

strcpy(a,aa); //用aa所指字符串初始化a所指向的动态存储空间 }

__ _(3)___ //定义析构函数,删除a所指向的动态存储空间

};

(3) p=new A(5)

11、答案:(1) A() {a=0;} 或A():a(0){} 注:数据0可用NULL代替

(2) new char[strlen(aa)+1]

(3) ~A() {delete []a;}

12、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

}

12、答案:(1) :a(aa),b(bb)

(2) A x(5),y(x) 注:x(5)与x=5等效,y(x) 与y=x等效

(3) A *p=&x

13、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

}

13、答案:(1) A(int aa=0, int bb=0){a=aa; b=bb;}

(2) p1=new A

(3) p2= new A(4,5)

14、一种类定义如下:

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)___;

}

}

14、(1) return gd_name (2) static int (3) return totalweight

四、阅读程序题:

1、 #include

#include

void main() {

char

a[5][10]={"student","worker","soldier","cadre","peasant"};

char s1[10], s2[10];

strcpy(s1,a[0]); strcpy(s2,a[0]);

for(int i=1;i<5;i++) {

if(strcmp(a[i], s1)>0) strcpy(s1,a[i]);

if(strcmp(a[i], s2)<0) strcpy(s2,a[i]);

}

cout<

}

2、 #include

#include

class CD {

char* a;

int b;

public:

void Init(char* aa, int bb)

{

a=new char[strlen(aa)+1];

strcpy(a,aa);

b=bb;

}

char* Geta() {return a;}

int Getb() {return b;}

void Output() {cout<

} dx;

void main()

{

CD dy;

dx.Init("abcdef",30);

dy.Init("shenyafen",3*dx.Getb()+5);

dx.Output();

dy.Output();

}

abcdef 30

shenyafen 95

3、#include

#include

class CD {

char* a;

int b;

public:

void Init(char* aa, int bb)

{

a=new char[strlen(aa)+1];

strcpy(a,aa);

b=bb;

}

char* Geta() {return a;}

int Getb() {return b;}

void Output() {cout<

void main()

{

CD dx,dy;

char a[20];

dx.Init("abcdef",30);

strcpy(a,dx.Geta());

strcat(a,"xyz");

dy.Init(a,dx.Getb()+20);

dx.Output();

dy.Output();

}

abcdef 30

abcdefxyz 50

4、

#include

#include

class A {

char *a;

public:

A(char *s) {

a=new char[strlen(s)+1]; strcpy(a,s);

cout<

}

~A() {

delete []a;

cout<<"Destructor!"<

};

void main() {

A x("xuxiaokai");

A *y=new A("weirong");

delete y;

}

xuxiaokai

weirong

Destructor!

Destructor!

5、

#include

class A {

int a;

public:

A(int aa=0): a(aa) {cout<

~A() {cout<<"Xxk";}

};

void main() {

A *p;

A x[3]={1,2,3},y=4;

cout<

p=new A[3];

cout<

delete []p;

cout<

}

1 2 3 4

0 0 0

XxkXxkXxk

XxkXxkXxkXxk

五、程序改错

1. 在下面的定义中,NODE是链表结点的结构,appendToList则是一函数,其功能是:在list所指向的链表的末尾添加一个新的值为x的结点,并返回表头指针。函数中有两处错误,指出错误所在行的行号并提出改正意见。

struct NODE{

int data;

NODE *next;

};

NODE* appendToList(NODE *list, int x){ //1行

NODE *p=new int; //2行

p->data=x; //3行

p->next=NULL; //4行

if(list==NULL) return p; //5行

NODE *p1=list; //6行

while(p1->next!=NULL) p1=p1->next; //7行,链表非空先找到表尾

p1=p; //8行,让原表尾指针指向新添加的结点

return list;

}

}

错误行的行号为__2____和___8_____。

分别改正为NODE *p=new NODE;和_strcpy(p1,p)__ p1->next=p; ___________。

2、假定要求下面程序输出结果为“d=800,f=60”,在第4-23行中存在着三条语句错误,请指出错误语句的行号并改正。

#include

class A { //1行

int a[10]; int n; //2行

public: //3行

A(int aa[], int nn): n(nn) { //4行

for(int i=0; i

} //6行

int Get(int i) {return a[i];} //7行

int SumA(int n); //8行

}; //9行

int A::SumA(int n) { //10行

int s=0; //11行

for(int j=0; j

return s; //13行

} //14行

void main() { //15行

int a[]={2,5,8,10,15,20}; //16行

A x(a,6); //17行

int d=1; //18行

for(int i=0; i<4; i++) d*=x.a[i]; //19行

int f=SumA(6); //20行

cout<<"d="<

cout<<"f="<

} //23行

错误行的行号为___5___、___19_____和__20______。

分别改正为_a[i]=aa[i]___________________、___ d*=x.Get(i);____________和___ int f=x.SumA(6)________________。

六、程序设计

1、根据下面类中Count函数成员的原型和注释写出它的类外定义。

class AA {

int* a;

int n;

int MS;

public:

void InitAA(int aa[], int nn, int ms) {

c语言期末测试题附答案

c语言期末测试题附答 案 集团标准化工作小组 #Q8QGGQT-GX8G08Q8-GNQGJ8-MHHGN#

课程代码:A100002 座位号: 《计算机技术基础(C 语言)》试卷A 姓名: 学号: 专业: 学院: 班级: 20 年 月 日 第一 部分 选择题(共 30 分) 一、单项选择题(本大题共 15 小题,每题只有一个正确答 案,答对一题得 2 分,共 30 分) 1、以下关于C 语言标识符的描述中,正确的是 【 】。 A )标 识符可以由汉字组成 B )标识符只能以字母开头 C )关键字可以作为用户标识符 D )Area 与area 是不同的标识符 2、使下列程序段输出“123,456,78”,键盘输入数据,正确的输入是【 】。 int i,j,k; scanf(“%d,%3d%d”,&i,&j,&k); printf(“%d,%d,%d \n”,i,j,k); 3、判断char 类型的变量c1是否为数字字符的正确表达式为 【 】。 A) (c1>=0)&&(c1<=9) B) (c1>=’0’)&&(c1<=’9’) C) ’0’<=c1<=’9’ D) (c1>=’0’)||(c1<=’9’) 4、若有语句int a=1,b=2,c=3;则以下值为0的表达式是 【 】。 A )’a’&&’b’ B )a<=b C )((a>b)||(b0;i--);后,变量i 的值为 【 】。 A )10 B )9 C )0 D )1 8、若有int *p1, *p2,k; 不正确的语句是 【 】 A. p1=&k B. p2=p1 C. *p1=k+12 D. k=p1+p2 9、在函数中未指定存储类别的局部变量,其隐含的存储类别是 【 】

c语言试题及答案

1、以下正确的说法是( B ) (A) 用户若需要调用标准库函数,调用前必须重新定义 (B) 用户可以重新定义标准库函数,若如此,该函数将失去原有含义 (C) 系统根本不允许用户重新定义标准库函数 (D) 用户若需调用标准库函数,调用前不必使用预编译命令将该函数所在文件包括到用户源文件中,系统自动去调 2、以下正确的函数声明形式是( A ) (A) double fun(int x, int y) (B) double fun(int x; int y) (C) double fun(int x, int y); (D) double fun(int x,y); 3、以下正确的函数形式是( D ) (A) double fun(int x, int y) { z=x+y; return z;} (B) fun(int x,y) { int z; return z;} (C) fun(x,y) { int x,y; double z; z=x+y; return z;} (D) double fun(int x, int y) { double z; z=x+y; return z;} 4、以下正确的说法是( A ) 在C语言中 (A) 实参和与其对应的形参各占用独立的存储单元 (B) 实参和与其对应的形参共占用一个存储单元 (C) 只有当实参和与其对应的形参同名时才共占用存储单元 (D) 形参是虚拟的,不占用存储单元 5、若调用一个函数,且此函数中没有return语句,则正确的说法是( A ) 该函数 (A) 没有返回值 (B) 返回若干个系统默认值 (C) 能返回一个用户所希望的函数值 (D) 返回一个不确定的值 6、以下不正确的说法是( B ) C语言规定 (A) 实参可以是常量、变量和表达式 (B) 形参可以是常量、变量和表达式 (C) 实参可以为任意类型 (D) 形参应与其对应的实参类型一致 7、以下正确的说法是( C ) (A) 定义函数时,形参的类型说明可以放在函数体内 (B) return后边的值不能为表达式 (C) 如果函数值的类型与返回值类型不一致,以函数值类型为准 (D) 如果形参与实参的类型不一致,以实参类型为准 8、C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是( B ) (A) 地址传递 (B) 单向值传递 (C) 由实参传给形参,再由形参传回给实参 (D) 由用户指定传递方式

C语言常见复习题(选择填空)及参考答案

C语言常见复习题及参考答案 一、选择题 1.下述标识符中,()是合法的用户标识符。 A.A#C B.getch C.void D.ab* 2.在C语言中,字符型数据在内存中是以()形式存放的。 A.原码 B.BCD码 C.反码 D.ASCII码 3.以下选项中不合法的用户标识符是()。 A.abc.c B.file C.Main D.PRONTF 4.以下选项中不合法的用户标识符是()。 A.123 B.printf C.Anbsp; D.Dim 5.可以在C语言程序中用做用户标识符的一组标识符是()。 A.void B.as-b3 C.for D.2c define -123 -abc Do WORD If cas SIG 6.在以下各组标识符中,合法的用户标识符是(1)、(2)、(3)。 (1)A.001 B.table_1 C.0_t D.k% Int t*.1 W10 point (2)A.Fast_ B.void C.pbl D. Fast+Big abs fabs beep (3)A.xy_ B.longdouble C.*p D.CHAR 变量1 signed history Float 7.()是构成C语言的基本单位。 A.函数 B.过程 C.子程序 D.子例程 8.若有说明:char s1='\067';char s2="1";char s3='1';则s1中(1),s2中(2),s3中(3)。

(1).A.包含3个字符 B.包含2个字符 C.包含1个字符 D.无定值,说明不合法 (2).A.包含1个字符 B.包含2个字符 C.包含3个字符 D.无定值,说明不合法 (3).A.包含1个字符 B.包含2个字符 C.包含3个字符 D.无定值,说明不合法 9.若x为int型变量,则执行以下语句后,x的值为 x=6; x+=x-=x*x A.36 B.-60 C.60 D.-24 10.在C语言中,char 型数据在内存中是以()形式存储的。 A.原码 B.补码 C.ASCII码 D.反码 11.以下运算符中优先级最低的算符为(),优先级最高的为()。 A.&& B.& C.|= D.|| E.?: F.!= 12.若有运算符>、*=、<<、%、sizeof,则它们按优先级(由低至高)的正确排列顺序为 A.*= << > % sizeof B.<< *= > % sizeof C.*= > << sizeof % D.*= > << % sizeof 13.若有以下类型说明语句 char w; int x; float y; double z; 则表达式w*x+z-y 的结果是()类型。 A.float B.char C.int D.double 14.若w,x,y,z 均为int 型变量,则执行下面的语句后, w=(1), x=(2), y=(3), z=(4)。 w=5; x=4; y=w++*w++*w++; z=--x*=--x*--x;

c期末考试试题及答案完整版

c期末考试试题及答案 HUA system office room 【HUA16H-TTMS2A-HUAS8Q8-HUAH1688】

AutoCAD 试卷 一、 单项选择 1、AutoCAD 默认扩展名是 A 、dwt B 、dwg C 、bak D 、dxf 答案:B 2、在CAD 中,以下哪个命令可用来绘制横 平竖直的直线 A 、栅格 B 、捕捉 C 、正交 D 、对象捕捉答案:C 3、按哪个键可切换文本窗口和绘图窗口 A 、F2 B 、F8 C 、F3 D 、F5答案:A 4、默认情况下,命令提示行显示为几行 A 、3 B 、5 C 、2 D 、8答案:A 5、在CAD 中为一条直线制作平行线用什么命令 A 、移动 B 、镜像 C 、偏移 D 、旋转答案:C 6、在图层特性管理器中不可以设定哪项 A 、颜色 B 、页面设置 C 、线 宽 D 、是否打印答案:B 7、绘制建筑图步骤为 A 、墙线、轴线、门窗 B 、墙线、 门窗、轴线 C 、轴线、门窗、墙线 D 、轴线、 墙线、门窗答案:D 8、哪个命令可用于绘制直线与圆弧的复合 体 A 、圆弧 B 、构造线 C 、多段线 D 、样条曲线答案:C 9、如何在图中输入“直径”符号 A 、%%P B 、%%C C 、%%D D 、%%U 答案:B

10、如果要在一个圆的圆心写一个“A”字,应使用以下哪种对正方式 A、中间 B、对齐 C、中心 D、调整答案:A 11、在哪个层创建的块可在插入时与当前层特性一致 A、0层 B、在所有自动产生的层 C、所有图层 D、新建的图层答案:A 12、一个完整的尺寸由几部分组成 A、尺寸线、文本、箭头 B、尺寸线、尺寸界线、文本、标记 C、基线、尺寸界线、文本、箭头 D、尺寸线、尺寸界线、文本、箭头 答案:D 13、要将图形中的所有尺寸都为原有尺寸的2倍,应设定以下哪项A、文字高度 B、使用全局比例 C、测量单位比例 D、换算单位 答案:B 14、三维模型中哪种模型可以进行布尔运算 A、线框模型 B、实心体模型 C、表面体模型答案:B 15、渲染三维模型时,哪种类型可以渲染出物体的所有效果 A、一般渲染 B、普通渲染 C、照片级真实感渲染 D、照片级光线跟踪渲染答案:D 16、样板文件的括展名是 A、BAK B、SVS C、DWT D、DWG 答案:C 17、以下哪种相对坐标的输入方法是画8个单位的线长 A.8, 0 B.@0,8 C.@0<8

c 试题及答案

一、单项选择题 1、下列哪个类型的对象是https://www.wendangku.net/doc/8917208148.html,在非连接模式下处理数据内容的主要对象? (D ) A. Command B. Connection C. DataAdapter D. DataSet 2、枚举类型是一组命名的常量集合,所有整形都可以作为枚举类型的基本类 型, 如果类型省略,则定义为( A )。 A. int B. sbyte C. uint D. ulong 3、创建数据库连接使用的对象是( A )。 A. Connection B. Command C. DataReader D. DataSet 4、C#中导入某一命名空间的关键字是( A )。 A. using B. use C.import D. include 5、一般情况下,异常类存放在什么命名空间中?( B )。 A. 生成异常类所在的命名空间 B. System.Exception命名空 间 C. System.Diagnostics命名空间 D. System命名空间 6、若将数据库中的数据填充到数据集,应调用SqlDataAdapter的( C )方 法。 A. Open B. Close C. Fill D. Update 7、若将数据集中所作更改更新回数据库,应调用SqlAdapter的(A )方法。 A. Update B. Close C. Fill D. Open 8、在使用FileStream 打开一个文件时,通过使用FileMode 枚举类型的( A ) 成员,来指定操作系统打开一个现有文件并把文件读写指针定位在 文件尾部。 A. Append B. Create C. CreateNew D. Truncate 9、在菜单项File中,为将F设为助记符,应将该菜单项的Text属性设置为 (B )。 A. @File B.&File C. %File D._File 10、指定操作系统读取文件方式中的FileMode .Create的含义是( D)。 A. 打开现有文件 B. 指定操作系统应创建文件,如果文件存在,将出现异常 C. 打开现有文件,若文件不存在,出现异常 D. 指定操作系统应创建文件,如果文件存在,将被改写 11、枚举类型是一组命名的常量集合,所有整形都可以作为枚举类型的基本类 型,如果类型省略,则定义为( D )。 A. uint B. sbyte C. ulong D. int 12、当运行程序时,系统自动执行启动窗体的( C )事件。 A. Click B.DoubleClick C. Load D. Activated

C语言练习题(带答案)

一、单项选择题 1.(A)是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 2.C语言程序从C开始执行。 A) 程序中第一条可执行语句B) 程序中第一个函数 C) 程序中的main函数D) 包含文件中的第一个函数 3、以下说法中正确的是(C)。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是(B )。 A) C程序的工作过程是编辑、编译、连接、运行 B) C语言不区分大小写。 C) C程序的三种基本结构是顺序、选择、循环 D) C程序从main函数开始执行 5.下列正确的标识符是(C)。 A.-a1 B.a[i] C.a2_i D.int t 6.下列C语言用户标识符中合法的是(B)。 A)3ax B)x C)case D)-e2 E)union 7.下列四组选项中,正确的C语言标识符是(C)。 A)%x B)a+b C)a123 D)123 8、下列四组字符串中都可以用作C语言程序中的标识符的是(A)。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# His.age 9.C语言中的简单数据类型包括(D)。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是C。 A)2.5 B)2 C)1 D)3 11.如果int a=3,b=4;则条件表达式"a

C期末考试题及答案

C期末考试题及答案 Revised at 2 pm on December 25, 2020.

一、填空题(每空0.5分,共30分) 1、世界坐标系简称__WCS_用户自定义坐标系简称__UCS_。 2、工作空间的切换:“工具”/“工作空间”或“工作空间”工具栏。 3、工具栏包括30种,系统默认的显示工具栏包括:“标准”、“属性”、“绘图”和“修改”等工具栏。 4、多线的对正方式有_上(T)_、_无(Z)_和_下(B)_。 5、文字标注包括标注单行文字和标注多行文字。 6、渲染环境是指在渲染对象时进行的雾化和深度设置。 7、漫游和飞行用户可以通过键盘和鼠标来控制视图显示,并创建导航动画。 8、编辑实体的边的种类:压印边、复制边、着色边。 9、动态块是通过自定义夹点或自定义特性定义的块。在图形中使用动态块,用户可以随时对组成块的对象进行修改。 10、三维实体是具有体积、质量、重心、回转半径、惯性距等特征的三维对象。 11、在AutoCAD 2007中,用户可以创建的光源有电光源、聚光灯光源和平行光光源。 12、相切、相切、半径法是指:通过指定圆的两个切点和半径来绘制圆。 13、绘制圆环的步骤中,先输入圆环的内径和外径,后确定圆环的中心点。 14、计算机辅助设计是:工程技术人员在CAD系统的辅助下,根据产品的设计程序进行设计的一项新技术。 15、菜单栏包括11种,每一种菜单中都含有四种显示情况:命令后跟右三角 、后跟省略号、后跟快捷键或功能键或命令呈灰色。 16、要对图形对象进行编辑就必须选中图形对象,在AutoCAD 2007中,选择对象的方法很多,常用的有_直接拾取_、矩形框选择_、_不规则区域选择_和快速选择。 17、在设置显示精度时,如果设置的精度越高,即分辨率就越高,计算机计算的时间 也越长,显示图形的速度也就越慢。 18、三维基本实体的种类包括:多段体、长方体、楔体、圆柱体、圆锥体、球体、圆环体、棱锥面。 19、布尔运算中只留重复的一部分的运算是交集运算。从一个图形中去掉与另一个图形重复部分的运算是差集运算。

c练习题(带答案)

一、选择题 1.C++语言属于( C )。 A)自然语言B)机器语言C)面向对象语言D)汇编语言2.下面选项中不属于面向对象程序设计特征的是(C) 。 A)继承性B)多态性C)相似性D)封装性 3.可用作C++语言用户标识符的一组标识符是( B )。 A)void define +WORD B)a3_b3 _123 YN C)for -abc Case D)2a DO sizeof 4.假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[2][1]的值为 (A)。 A)0 B)4 C)8 D)6 5.下列情况中,哪一种情况不会调用拷贝构造函数( B ) A)用派生类的对象去初始化基类对象时 B)将类的一个对象赋值给该类的另一个对象时 C)函数的形参是类的对象,调用函数进行形参和实参结合时 D)函数的返回值是类的对象,函数执行返回调用者时 6.以下哪一关键字可用于重载函数的区分(C) A)extern B)static C)const D)virtual 7.下列有关数组的叙述中,正确的是( B ) A)C++中数组的存储方式为列优先存储 B)数组名可以作为实参赋值给指针类型的形参 C)数组下标索引从1开始,至数组长度n结束 D)数组指针的语法形式为:类型名*数组名[下标表达式]; 8.下列有关继承和派生的叙述中,正确的是( C) A)派生类不能访问通过私有继承的基类的保护成员 B)多继承的虚基类不能够实例化 C)如果基类没有默认构造函数,派生类就应当声明带形参的构造函数 D)基类的析构函数和虚函数都不能够被继承,需要在派生类中重新实现 9.实现运行时多态的机制是( A ) A)虚函数B)重载函数C)静态函数D)模版函数 10.若有下面的函数调用:

c语言期末测试题(附答案)

课程代码: A100002 《计算机技术基础( C 语言)》试卷 A 姓名: 学号: 专业 : 学院 : 班级 : 20 年 月 日 选择题(共 30 分) 题(本大题共 15 小题,每题只有一个正确答案,答 分,共 30 分) 1、以下关于 C 语言标识符的描述中,正确的是 【 】。 A) 标识符可以由汉字组成 B )标识符只能以字母开头 C )关键字可以作为用户标识符 D ) Area 与 area 是不同的标识符 2、使下列程序段输出“ 123, 456,78”,键盘输入数据,正确的输入是【 】 int i,j,k; scanf( “%d,%3d%”d ,&i,&j,&k); printf( “%d,%d,%dn ”,i,j,k); A ) 12345678 B )123,456, 78 C ) 123,45678 D ) 123,*45678 3、判断 char 类型的变量 c1 是否为数字字符的正确表达式为 【 】。 A) (c1>=0)&&(c1<=9) B) (c1>= '0')&&(c1<='9') C) '0'<=c1<='9' D) (c1>= '0')||(c1<= '9') 4、若有语句 int a=1,b=2,c=3 ;则以下值为 0 的表达式是 【 】。 A )' a '&&'b ' B )a<=b C )((a>b)||(b

计算机技术基础试题 第 2 页(共 10 页) A. *(a[0]+2) B. a[1][3] C . a[1][0] D. *(*(a+1)+2) 6、在循环语句的循环体中执行 break 语句,其作用是 【 】。 A )跳出该循 环体,提前结束循环 B) 继续执行 break 语句之后的循环体各语句 C) 结束本次循环,进行下次循环 D) 终止程序运行 7、执行语句 for(i=10;i>0;i--) ;后,变量 i 的值为 【 】。 A ) 10 B )9 C )0 D )1 8、若有 int *p1, *p2, k; 不正确的语句是 【 】 A. p1=&k B. p2=p1 C. *p1=k+12 D. k=p1+p2 9、在函数中未指定存储类别的局部变量,其隐含的存储类别是 【 】 A. 静态( static ) B. 外部( extern ) C. 自动( auto ) D . 寄存器( register ) 10、如下程序的输出结果是 【 】 main( ) { int x=2,a=0,b=0; switch(x) { case 2: a++; b++; case 1: ++a; b--; break; case 0: b++;} printf("a=%d, b=%d\n", a, b);} A. a=2, b=0 B. a=2, b=1 C. a=1, b=1 D. a=1, b=0 11、表示关系 a

C语言试题及答案

第1章 C语言概述习题 1. 单项选择题 (1) C 语言是在 B 语言的基础上产生的。 A. A B. B C. D D. E (2) 在 C 语言中,每个语句必须以 D 结束。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (3) 标识符和关键字间,要用 C 隔开。 A. 回车符 B. 冒号 C. 空格 D. 分号 (4) 用 C 语言编写的源文件经过编译,若没有产生编译错误,则系统将( B )。 A. 生成可执行目标文件 B. 生成目标文件 C. 输出运行结果 D.自动保存源文件 (5) 下列说法中正确的是( B )。 A. 由于 C 源程序是高级语言程序,因此一定要在 TC 软件中输入 B. 由 C 源程序是字符流组成,因此可以作为文本文件在任何文本编辑的软件中输入 C. 由于C 程序是高级语言程序,因此输入后即可执行 D. 由于 C 程序是高级语言程序,因此它由命令组成 (6) 下列说法中正确的是( A )。 A. C 语言程序由主函数和 0 个或多个函数组成 B. C 语言程序由主程序和子程序组成 C. C 语言程序由子程序组成 D. C 语言程序由过程组成 (7) 下列说法中错误的是( D )。 A. 主函数可以分为两个部分:主函数说明部分和主函数体 B. 主函数可以调用任何非主函数的其他函数 C. 任何非主函数可以调用其他任何非主函数 D. 程序可以从任何非主函数开始执行 2. 填空题 (1) C 语言只有 32 个关键字和 9 种控制语句。 (2) C 语言是一种“中级语言”,既具有高级语言的特点又具有低级语言的特点;既适合于开发系统软件又适合于编写应用程序。 (3) 每个源程序有且只有一个主函数,系统总是从该函数开始执行C语言程序。 (4) 在 C 语言程序中允许出现的字符集是 ASCII码字符集。 (5) C 语言的程序中有特殊含义的英语单词称为保留字。 (6) C 语言标识符的长度是前 8 位有效。 (7) C 语言中,标识符的定义规则是以字母或下划线为开头。 (8) C 语言程序的注释可以出现在程序中的任何地方,它总是以 /* 符号作为开始标记,以 */ 符号作为结束标记。 第2章数据类型运算符和表达式习题 1. 单项选择题 (1) 以下选项中,正确的 C 语言整型常量是 D 。 A. 32L B. 510000 C. -1.00 D. 567 (2) 以下选项中, D 是不正确的 C 语言字符型常量。

c练习题带答案

c练习题带答案集团标准化工作小组 #Q8QGGQT-GX8G08Q8-

一、选择题 1.C++语言属于( C )。 A)自然语言 B)机器语言 C)面向对象语言 D)汇编语言2.下面选项中不属于面向对象程序设计特征的是(C) 。 A)继承性 B)多态性 C)相似性 D)封装性 3.可用作C++语言用户标识符的一组标识符是( B )。 A) void define +WORD B) a3_b3 _123 YN C) for -abc Case D) 2a DO sizeof 4.假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素 a[2][1]的值为(A)。 A) 0 B) 4 C) 8 D) 6 5.下列情况中,哪一种情况不会调用拷贝构造函数( B ) A)用派生类的对象去初始化基类对象时 B)将类的一个对象赋值给该类的另一个对象时 C)函数的形参是类的对象,调用函数进行形参和实参结合时 D)函数的返回值是类的对象,函数执行返回调用者时 6.以下哪一关键字可用于重载函数的区分(C) A)extern B)static C)const D)virtual 7.下列有关数组的叙述中,正确的是( B ) A)C++中数组的存储方式为列优先存储 B)数组名可以作为实参赋值给指针类型的形参 C)数组下标索引从1开始,至数组长度n结束 D)数组指针的语法形式为:类型名 *数组名[下标表达式]; 8.下列有关继承和派生的叙述中,正确的是( C ) A)派生类不能访问通过私有继承的基类的保护成员 B)多继承的虚基类不能够实例化 C)如果基类没有默认构造函数,派生类就应当声明带形参的构造函数 D)基类的析构函数和虚函数都不能够被继承,需要在派生类中重新实现 9.实现运行时多态的机制是( A ) A)虚函数B)重载函数C)静态函数D)模版函数 10.若有下面的函数调用: fun(a+b, 3, max(n-1, b)); 其中实参的个数是( A) A)3 B)4 C)5 D)6 11.下列关于this指针的说法正确的是( B)

C语言程序设计期末考试试题(含答案)

C语言程序设计 期末考试试题及其答案 一、单项选择题(本大题共20题,每题2 分,共40分) 1、以下不是C语言的特点的是( ) A、C语言简洁、紧凑 B、能够编制出功能复杂的程序 C、C语言可以直接对硬件进行操作 D、C语言移植性好 2、以下不正确的C语言标识符是( ) A、ABC B、abc C、a_bc D、ab.c 3、一个C语言程序是由( ) A、一个主程序和若干子程序组成 B、函数组成 C、若干过程组成 D、若干子程序组成 4、一个算法应该具有“确定性”等5个特性,对另外4个特性的描述中错误的是( ) A、有零个或多个输入 B、有零个或多个输出 C、有穷性 D、可行性 5、设变量a是整型,f是实型,i是双精度型,则表达式10+‘a’+i*f值的数据类型为( ) A、int B、float C、double D、不确定 6、在C语言中,char型数据在内存中的存储形式是( ) A、补码 B、反码 C、源码 D、ASCII码 7、有如下程序,输入数据:12345M678<cR>后(表示回车),x的值是( ) 。 #include main(){ int x; float y; scanf("%3d%f",&x,&y); } A、12345 B、123 C、45 D、345 8、若有以下定义int a,b; float x,则正确的赋值语句是( ) A、a=1,b=2 B、b++; C、a=b=5 D、b=int(x); 9、以下程序的执行结果是( )

#include { int i=10,j=10; printf("%d,%d\n",++i,j--); } A、11,10 B、9,10 C、11,9 D、10,9 10、巳知字母A的ASCII码是65,以下程序的执行结果是( ) #include main() { char c1='A',c2='Y'; printf("%d,%d\n",c1,c2); A、A,Y B、65,65 C、65,90 D、65,89 11、下列运算符中优先级最高的是( ) A、< B、十 C、% D、!= 12、设x、y和z是int型变量,且x=3,y=4,z=5,则下面表达式中值为0是( ) 。 A、’x’&&’y’ B、x<=y C、x||y+z&&y-z D、!((x<y)&&!z ||1) 13、判断char型变量cl是否为小写字母的正确表达式为( ) A、’a’<=c1<=f’z’ B、(c1>=a)&&(c1<=z) C、(‘a’>=c1) (‘z’<=c1) D、(c1>=’a’)&&(c1<=’z’) 14、字符串"a"在内存中占据的字节个数为( ) A、0 B、 1 C、 2 D、 3 15、下面有关for循环的正确描述是( ) A、for循环只能用于循环次数已经确定的情况 B、for循环是先执行循环体语句,后判定表达式 C、在for循环中,不能用break语句跳出循环体 D、for循环体语句中,可以包含多条语句,但要用花括号括起来 16、下面程序的运行结果是( ) #include main() {int num=0; while(num<=2) {num++; printf(“%d ,num); } } A、 1 B、 1 2 C、 1 2 3

C语言试题及答案

一、单项选择题 1. 软件危机具有下列表现( d )。 I. 对软件开发成本估计不准确II. 软件产品的质量往往靠不住 III. 软件常常不可维护IV. 软件成本逐年上升 A. I、II和III B. I、III和IV C. II、III和IV D. 以上都正确 2. 软件生命周期一般都被划分为若干个独立的阶段,其中占用精力和费用最多的阶段往往是( A )。 A. 运行和维护阶段 B. 设计阶段 C. 代码实现阶段 D. 测试阶段 3. 下列属于软件的特点的是(D )。 A. 软件是一种逻辑实体,具有抽象性 ~ B. 软件在使用过程中没有磨损、老化的问题 C. 软件不同于一般程序,它的一个显著特点是规模庞大,复杂程度高 D. 以上都正确 4. 软件工程的出现是由于(D )。 A. 软件危机的出现 B. 计算机硬件技术的发展 C. 软件社会化的需要 D. 计算机软件技术的发展 5. 软件开发技术不包含( d )。 A. 软件开发方法学 B. 软件工程环境 C. 软件工具 D. 软件质量度度量 6. 软件工程的课程特点( D )。 【 I. 学科理论及其知识应用的多维性 II. 工程化 III. 浓厚的方法学色彩 IV. 实践性、指导性强 A. I、II和III B. I、III和IV C. II、III和IV D. 以上都正确 7. 下列属于应用软件的是( b )。 I. 计算机辅助教学软件II. 软件测试工具 III. 办公自动化软件IV. 工程与科学计算软件

A. I、II和III B. I、III和IV C. II、III和IV D. 以上都正确 8. 需求分析阶段最重要的技术文档是( b )。 - A. 设计说明书 B. 需求规格说明书 C. 可行性分析报告 D. 用户手册 9. 以下关于数据流图的说法错误的是( c )。 A. 数据流图舍去了具体的物质,只剩下数据的流动、加工处理和存储 B. 数据流图是用作结构化分析的一种工具 C. 传统的数据流图中主要由加工、数据源点/终点、数据流、控制流、数据存储组成 D. 数据流图的绘制采用自上向下、逐层分解的方法 10. 数据字典是软件需求分析阶段的最重要工具之一,其最基本的功能是( c )。 A. 数据库设计 B. 数据通信 C. 数据定义 D. 数据维护 11. 需求分析阶段的研究对象是( b )。 ¥ A. 系统分析员要求 B. 用户要求 C. 软硬件要求 D. 系统要求 12. 结构化方法的基本原则是( b )。 A. 模块化 B. 抽象与分解 C. 信息隐蔽 D. 逐步求精 13. 耦合度最高的是(b)耦合。 A. 环境 B. 内容 C. 控制 D. 数据 14. 内聚程度较低的是( a )内聚。 A. 偶然 B. 通讯 C. 顺序 D. 时间 15. 对一个程序来说,组成系统的模块数目( b ),则开发成本越小。 A. 越多 B. 越少 C. 顺序 D. 时间> 16. 画软件结构图时应注意调用关系只能是(B )。 A. 从下到上 B. 从上到下 C. 从左到右 D. 从右到左 17. 程序流程图中的箭头代表( b )。 A. 数据流 B. 控制流 C. 顺序流 D. 调用 18. 软件测试是软件质量保证的重要手段,下述( B )是软件测试的最基础环节。

C详细答案复习题c

第3章运算符和表达式 丰富的运算符可使表达式方便、简捷。初学者一下掌握这么多操作符会有压力。可通过写或计算表达式的练习,以及各章程序实例中出现的表达式,进一步熟悉运算符。 3.1 表达式的基本概念 对数据进行各种运算的符号为运算符,参与运算的数据为操作数。表达式构成:常量、变量、有返回值的函数调用是表达式,表达式加圆括号、或用运算符作正确连接后也是表达式。 圆括号左、右括号个数要相同,多层括号时内层括号中的运算优先;整个表达式必须写在同一行上。 a·x3+b·x2+c·x+d 写作 a*x*x*x+b*x*x+c*x+d 或 ((a*x+b)*x+c)*x+d; 写作 1/(1+1/(1+x));等等。 C运算符:算术、关系、逻辑、条件、赋值、逗号运算符,等等。 根据参与运算的操作数个数,运算符可分为单目、双目以及三目运算符。两个操作数的运算符是双目运算符,“单目运算符”只有一个操作数。三目运算符是C语言所特有的,它有三个操作数。 不同运算符参与运算时有优先级问题。如先乘除、后加减。 同级运算一般是从左向右进行。特例如赋值“x=y=3”,先计算y=3、再计算x=y。特例将特别指出,一般按缺省。 主要介绍算术(包括自增自减)、关系、逻辑、赋值、逗号运算符,以及由这些运算符构成的各类表达式。 3.2 算术运算符与算术表达式 内容:算术运算符及其功能,算术表达式,优先级、运算时的类型转换规则。 3.2.1 算术运算符 1. 算术运算符 C的算术运算符有:+ - * / %(取余) 其中“-”可作单目运算符,如-5,表达式3*-5值为-15。 各运算符优先级:先乘除、后加减;取余的优先级和乘除相同。 优先级的讨论,应限于同一层括号内,同级运算一般从左到右执行。具体规则如下:

C期末考试试卷及答案

C++期末考试试卷及答案1 一、单项选择题(每题2分,共40分) 1. ______不是属于面向对象程序设计的特性 A. 抽象性 B. 数据相关性 C. 多态性 D. 继承性 2. 将对某一类数据的处理算法应用到另一类数据的处理中,要用到C++的______ A. 类 B. 虚函数 C. 运算符重载 D. 模板 3. C++与C语言最根本的不同之处在于_______ A. 使用了类 B. 能够实现变量自动初始化 C. 支持软件重用 D. 支持接口重用 4. 动态内存分配的主要目的是_______ A. 使程序按动态联编方式运行 B. 正确合理的使用内存 C. 提高程序的运行速度 D. 提高程序的可维护性 5. 在C++函数的形参前加const关键字,是为了提高函数的_______ A. 数据封装性 B. 可理解性 C. 可维护性 D. 可重用性 6. 函数重载的目的是________ A. 实现共享 B. 使用方便,提高可读性 C. 提高速度 D. 减少空间 7. 从程序片断:char name[] = "C++"; course(name);可判断函数course的调用采用的是_______ A. 传值调用 B. 带缺省参数值的函数调用 C. 引用调用 D. 传址调用 8. 用来说明类中公有成员的关键字是________

9. 如果一个类的成员函数print()不修改类的数据成员值,则应将其声明为 A. void print() const; B. const void print(); C. void const print(); D. void print(const); 10. 下列关于构造函数的论述中,不正确的是_______ A. 构造函数的函数名与类名相同 B. 构造函数可以设置默认参数 C. 构造函数的返回类型缺省为int型 D. 构造函数可以重载 11. 在程序代码:A::A(int a, int *b) { this->x = a; this->y = b; }中,this的类型是______ A. int B. int * C. A D. A * 12. 内存泄漏是指_______ A. 内存中的数据出现丢失 B.试图释放一个已经释放了的动态分配的堆内存 C. 函数中局部变量所占的栈内存没有及时回收 D. 动态分配的堆内存在程序退出后始终被占用 A. 私有成员数据 B. 私有成员函数 C. 公有成员数据 D. 公有成员函数 14. 友元函数_______ A. 可以被声明为const B. 没有this指针 C. 可以用类名或对象名来调用 D. 只能用对象名来调用 15. 若一个类的成员函数前用static关键字修饰,则该成员函数________ A. 可以被声明为const B. 没有this指针 C. 可以访问该类的所有成员 D. 只能用对象名来调用 16. C++是用_______实现接口重用的

C试题及答案一

C++程序设计模拟试卷(一) 一、单项选择题(本大题共20小题,每小题1分,共20分)在每小题列出的四个备选项中 只有一个是符合题目要求的,请将其代码填写在题后的括号内。错选、多选或未选均无 分。 1. 编写C++程序一般需经过的几个步骤依次是() A. 编辑、调试、编译、连接 B. 编辑、编译、连接、运行 C. 编译、调试、编辑、连接 D. 编译、编辑、连接、运行 答案:B 解析:经过编辑、编译、连接和运行四个步骤。编辑是将C++源程序输入计算机的过程,保 存文件名为cpp。编译是使用系统提供的编译器将源程序cpp生成机器语言的过程,目标文件为 obj,由于没有得到系统分配的绝对地址,还不能直接运行。连接是将目标文件obj转换为可执行 程序的过程,结果为exe。运行是执行exe,在屏幕上显示结果的过程。 2. 决定C++语言中函数的返回值类型的是() A. return语句中的表达式类型 B. 调用该函数时系统随机产生的类型 C. 调用该函数时的主调用函数类型 D. 在定义该函数时所指定的数据类型 答案:D 解析:函数的返回值类型由定义函数时的指定的数据类型决定的。A项的表达式的值要转换 成函数的定义时的返回类型。 3. 下面叙述不正确的是() A. 派生类一般都用公有派生 B. 对基类成员的访问必须是无二义性的 C. 赋值兼容规则也适用于多重继承的组合 D. 基类的公有成员在派生类中仍然是公有的 答案:D 解析:继承方式有三种:公有、私有和保护。多继承中,多个基类具有同名成员,在它们 的子类中访问这些成员,就产生了二义性,但进行访问时,不能存在二义性。赋值兼容规则是指 派生类对象可以当作基类对象使用,只要存在继承关系,所以单继承或多继承都适用。基类中的 公有成员采用私有继承时,在派生类中变成了私有成员,所以D项错误。 4. 所谓数据封装就是将一组数据和与这组数据有关操作组装在一起,形成一个实体,这实体 也就是() A. 类 B. 对象 C. 函数体 D. 数据块 答案:A 解析:类即数据和操作的组合体,数据是类的静态特征,操作是类具有的动作。 5. 在公有派生类的成员函数不能直接访问基类中继承来的某个成员,则该成员一定是基类中 的() A. 私有成员 B. 公有成员 C. 保护成员 D. 保护成员或私有成员 答案:A 解析:在派生类中基类的保护或者基类公有都可以直接访问,基类的私有成员只能是基类 的成员函数来访问。所以选择A项。 6. 对基类和派生类的关系描述中,错误的是() A. 派生类是基类的具体化 B. 基类继承了派生类的属性 C. 派生类是基类定义的延续 D. 派生类是基类的特殊化 答案:B 解析:派生类的成员一个是来自基类,一个来自本身,所以派生类是基类的扩展,也是基 类的具体化和特殊化,派生类是对基类扩展。B项基类不能继承派生类成员,所以错误。 7. 关于this指针使用说法正确的是() A. 保证每个对象拥有自己的数据成员,但共享处理这些数据的代码

C考试复习题及答案

一、选择题 (1)下面关于类和对象的描述中,错误的是 A)类就是C语言中的结构体类型,对象就是C语言中的结构体变量 B)类和对象之间的关系是抽象和具体的关系 C)对象是类的实例,一个对象必须属于一个已知的类 D)类是具有共同行为的若干对象的统一描述体 (2)以下各选项组中,均是C++语言关键字的组是 A) public operator this B)shod string static C)it while >= D)private cout printf (3)在C++语言中,数据封装要解决的问题是 A)数据的规范化B)便于数据转换 C)避免数据丢失D)防止不同模块之间数据的非法访问 (4)以下程序中,错误的行是 ①#include ②class A ③{ ④ public: ⑤ int n=2: ⑥ A( int val){cout< class A { int num; public: A(int i){num=i;} A(A &a){num=a. num++;} void print(){cout<

相关文档