当前位置:文档之家› 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语言程序设计》考试试卷(答案) 一、填空题(每小空1分,共10分) 1.C语言程序的三种基本结构是顺序结构、选择结构、循环结构。 2.一个C程序有且仅有一个main( ) 函数。 3.C语言描述“x和y都大于或等于z”的表达式是x>=z && y>=z。 4.C语言可以用来实现循环的结构化语句是while、do while、for。 5.数组名表示数组在内存的首地址。 6.int a=3,*p=&a;*p+2的值是5。 二、单项选择题(每小题2分,共70分) 1.__B___是C语言合法的常量。 (A).45(B)078 (C)25.6e3.4 (D)‘xy’2.一个程序的执行是从 A 。 (A)本程序的main函数开始,到main函数结束 (B)本程序文件的第一个函数开始,到本程序文件的最后一个函数结束。 (C)本程序的main函数开始,到本程序文件的最后一个函数结束。 (D)本程序文件的第一个函数开始,到main函数结束。 3.以下叙述正确的是 C 。 (A)在C程序中,main函数必须位于程序的最前面。 (B)C程序每行中只能写一条语句。 (C)C语言本是没有输入输出语句。 (D)在对一个C程序进行编译的过程中,可发现注释中的拼写错误。 4.以下叙述不正确的是 D 。 (A)逗号运算符的运算级最低。 (B)ABC和abc是两个不同的变量。 (C)若a和b类型相同,在执行a=b后,b的自身值不变。 (D)‘a’和“a”是完全等价的常量。 5.int x=3,y=2;则表达式x+=x*=y+8的值为 C 。 (A)28 (B)30 (C)60(D)17 6.设x=2.7,a=8,y=4.9,算术表达式x+a%3*(int)(x+y)%5/3的值为 B 。 (A)2.7 (B)3.7(C)4.7 (D)4.03 7.执行下面两个语句后,输出的结果为__D___。 char c1=98; printf(“%d %c”,c1,c1-32); (A)97 66 (B)98 b (C)b 66 (D)98 B 8.执行下面语句后的结果为 C 。 y=10;x=y++; (A)x=10,y=10 (B)x=11,y=11 (C)x=10,y=11(D)x=11,y=10 9.Char w;int x;float y;double z;则表达式w*x+z-y值的数据类型是A 。 (A)double (B)char (C)int (D)float 10.C语言中要求操作数必须是整数的运算符是 B 。

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语言试题及答案

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 语言理论上机考试选择题部分(共200题) 1、下面程序的输出是___D______ #include void main() { int k=11; printf("k=%d,k=%o,k=%x\n",k,k,k); } A) k=11,k=12,k=11 B) k=11,k=13,k=13 C) k=11,k=013,k=0xb D) k=11,k=13,k=b 2、在下列选项中,不正确的赋值语句是__D______. A) ++t; B) n1=(n2=(n3=0)); C) k=i=j; D) a=b+c=1; 3、下面合法的C 语言字符常量是______A____. A) '\t' B) "A" C) 65 D) A 4、表达式: 10!=9的值是 ________D____. A) true B) 非零值 C) 0 D) 1 5、C 语言提供的合法的数据类型关键字是_____B____. A) Double B) short C) integer D) Char 6、字符(char)型数据在微机内存中的存储形式是__D__. A) 反码 B) 补码 C) EBCDIC 码 D) ASCII 码 7、C 语言程序的基本单位是_____C______. A) 程序行 B) 语句 C) 函数 D) 字符 8、设 int a=12,则执行完语句

a+=a-=a*a 后,a 的值是____D____ A) 552 B) 264 C) 144 D) -264 9、执行下面程序中的输出语句后,输出结果是____B__. #include void main() {int a; printf("%d\n",(a=3*5,a*4,a+5)); } A) 65 B) 20 C) 15 D) 10 10、下面程序的输出是____B______. #include void main() {int x=023; printf("%d\n",--x); } A) 17 B) 18 C) 23 D) 24 11、下面程序的输出的是_____C____. #include void main() {int x=10,y=3; printf("%d\n",y=x/y); } A) 0 B) 1 C) 3 D) 不确定的值 12、已知字母A 的ASCII 码为十进制的65,下面程序的输出是______A_____. #include void main() {char ch1,ch2; ch1='A'+'5'-'3'; ch2='A'+'6'-'3'; printf("%d,%c\n",ch1,ch2); } A) 67,D B) B,C C) C,D D) 不确定的值 13、若要求在if 后一对圆括号中表示a 不等于0的关系,则能正确表示这一关系的表达式为____D__. A) a<>0 B) !a C) a=0 D) a

c 试题及答案

一、单项选择题 1、下列哪个类型的对象是https://www.doczj.com/doc/9d14965873.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语言 一、选择题(第题2分,共20分) 1.一个C程序的执行是从 A 。 A) 本程序的main函数开始,到main函数结束 B) 本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C) 本程序文件的第一个函数开始,到本程序main函数结束 D) 本程序的main函数开始,到本程序文件的最后一个函数结束 2.若x、i、j、k都是int型变量,则计算下面表达式后,x的值为 C 。 x=(i=4,j=16,k=32) A) 4 B) 16 C) 32 D) 52 3.设C语言中,一个int型数据在内存中占2个字节,则unsigned int 型数据的取值范围为 C 。 A) 0~255 B) 0~32767 C) 0~65535 D) 0~2147483647 4.设有说明:char w; int x; float y; double z;则表达式w*x+z-y值的数据类型为 D 。 A) float B) char C) int D) double 5. putchar函数可以向终端输出一个 D 。 A) 整型变量表达式 B) 实型变量值 C) 字符串 D) 字符或字符型变量值 6. printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列。如果字符串长度大于5,则输出按方式 B ;如果字符串长度小于5,则输出按方式 C 。 A) 从左起输出该字符串,右补空格 B) 按原字符长从左向右全部输出 C) 右对齐输出该字符串,左补空格 D) 输出错误信息 7.判断char型变量ch是否为大写字母的正确表达式是 C 。 A) ‘A’<=ch<=‘Z’ B) (ch>=‘A’)&(ch<=‘Z’) C) (ch>=‘A’)&&(ch<=‘Z’) D) (‘A’<= ch)AND(‘Z’>= ch) 8.已知int x=10,y=20,z=30;以下语句执行后x,y,z的值是 B 。 if(x>y) z=x; x=y; y=z; A) x=10, y=20, z=30 B) x=20, y=30, z=30 C) x=20, y=30, z=10 D) x=20, y=30, z=20 9.以下程序段______C__. x=-1; do{ x=x*x; } while(!x); A)是死循环 B)循环执行二次 C)循环执行一次 D)有语法错误 10.以下正确的描述是___B____. A)continue语句的作用是结束整个循环的执行

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语言全部题目及答案

C语言全部题目及答案 SANY GROUP system office room 【SANYUA16H-

C语言全部题目及答案 Exercise 1: Programming Environment and Basic Input/Output 1.Write a program that prints “This is my first program!” on the screen. (a)Save this program onto your own disk with the name of e2-1a; (b)Run this program without opening Turbo C; (c)Modify this program to print “This is my second program!”, then save it as e2-1b. Please do not overwrite the first program. 2.Write a program that prints the number 1 to 4 on the same line. Write the program using the following methods: (a)Using four “printf” statements. (b)Using one “printf” statement with no conversion specifier(i.e. no ‘%’). (c)Using one “printf” statement with four conversion specifiers 3.(a) Write a program that calculates and displays the number of minutes in 15 days. (b) Write a program that calculates and displays how many hours 180 minutes equal to. (c) (Optional) How about 174 minutes?

大学C语言考试题库及答案

精选考试类应用文档,如果您需要使用本文档,请点击下载,另外祝您生活愉快,工作顺利,万事如意! 大学C语言考试题库及答案 姓名成绩 温馨提示:同学们,经过培训学习,你一定积累了很多知识,现在请认真、仔细地完成这张试题库吧。加油! 一单项选择题库 1. 在C语言中,以 D 作为字符串结束标志 A)’\n’ B)’ ’ C) ’0’ D)’\0’ 2.下列数据中属于“字符串常量”的是( A )。 A.“a” B.{ABC} C.‘abc\0’ D.‘a’ 若干个字符构成字符串 在C语言中,用单引号标识字符;用双引号标识字符串 选项B,C,分别用{}和’’标识字符串 选项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 。

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语言基本概念的掌握情况,读者可根据学习进度选做部分习题。在完成习题的过程中,不但要选出正确的答案,而且要清楚不正确的选项错在何处,以加深对概念的理解。对于掌握不准的问题, 应该通过上机实验来检验。 【1.1】以下不正确的C语言标识符是____。 A) int B) a_1_2 C) ab1exe D) _x 【1.2】以下是正确的C语言标识符是____。 A) #define B) _123 C) %d D) \n 【1.3】下列四组字符串中都可以用作C语言程序标识符的一组是。 ??? A) print B) i\am C) Pxq D) str_l ??? _3d one_half My->book Cpp ??? oodb start$it line# pow ??? aBc 3pai His.age while

【1.4】下面各选项组中,均是C语言关键字的组是。 A) auto,enum,include B) switch,typedef,continue C) signed,union,scanf D) if,struct,type 【1.5】下列不属于C语言关键字的是。A) default B) register C) enum D) external 【1.6】C语言程序从main()函数开始执行,所以这个函数要写在____。 A) 程序文件的开始B) 程序文件的最后 C) 它所调用的函数的前面D) 程序文件的任何位置 【1.7】下列关于C语言的叙述错误的是____ A) 大写字母和小写字母的意义相同 B) 不同类型的变量可以在一个表达式中 C) 在赋值表达式中等号(=)左边的变量和右边的值可以是不同类型 D) 同一个运算符号在不同的场合可以有不同的含义

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语言期末考试题含答 案 文档编制序号:[KKIDT-LLE0828-LLETD298-POI08]

《C 语言程序设计》期末试卷 一、单项选择题(10x2’=20’) 1、以下叙述正确的是( ) A )C 语言的源程序不必通过编译就可以直接运行。 B ) C 语言中的每条可执行语句最终都将被转换成二进制的机器指令。 C )C 语言源程序经编译形成的二进制代码可以直接运行。 D )C 语言中的函数不可以单独进行编译。 2、一个C 语言的源程序中( ) A )必须有一个主函数 B )可能有多个主函数 C )必须有除主函数外其它函数 D )可以没有主函数 3、以下不能定义为用户标识符的是( ) A )scanf B )Void C )_3com D )int 4、若以下选项中的变量已正确定义,则正确的赋值语句是( ) A )x1=%3; B )1+2=x2; C )x3=0x12; D )x4=1+2=3; 5、设有定义:float a=2,b=4,h=3;以下C 语言表达式中与代数式h b a *)(21 的计算结果不. 相符的是( ) A )(a+b)*h/2 B )(1/2)*(a+b)*h C )(a+b)*h*1/2 D )h/2*(a+b) 6、C 语言中用于结构化程序设计的3种基本结构是( ) A )顺序结构、选择结构、循环结构 B )if 、switch 、break C )for 、while 、do-while D )if 、for 、continue

7.在while(!x)语句中的!x与下面条件表达式等价的是() A) x!=0 B) x==1 C) x!=1 D) x==0 8、有以下程序: #include <> void main(){ int i=1,j=1,k=2; if( (j++||k++)&&i++ ) printf(“%d,%d,%d\n”,i,j,k);} 执行后的输出结果是() A)1,1,2B)2,2,1C)2,2,2D)2,2,3 9、有以下程序: #include <> void main(){ int i,s=0; for(i=1;i<10;i+=2) s+=i+1; printf(“%d\n”,s);} 程序执行后的输出结果是() A)自然数1~9的累加和B)自然数1~10的累加和 C)自然数1~9中奇数之和D)自然数1~10中偶数之和 10、有以下函数定义: void fun(int n,double x){……} 若以下选项中的变量都已经正确定义并赋值,则对函数fun的正确调用语句是() A)fun(int y,double m); B)k=fun(10,; C)fun(x,n); D)void fun(n,x); 二、填空题(10x2’=20’) 11、C语言描述“x和y都大于或等于z”的表达式是:。 12、函数定义时涉及的基本要素是:、、。

(完整版)C语言选择题(附答案)

第一单元C语言概述 一、选择题 1、C语言中主函数的个数为(A)个。 A)1 B)2 C)无穷个D)任意个 2、以下关于C语言描述错误的是(D)。 A)一个C程序总是从main函数开始执行T B)每个语句和数据声明的最后必须有一个分号T C)C语言的注释符是以“/*”开始并以“*/”结束的T D)一个C程序可以包含多个main函数F 3、C 语言源程序文件后缀为(C )。 A).EXE B).OBJ C).C D).ASM 4、C语言是由(C )组成的。 A)子程序B)主程序与子程序C)函数D)过程 5、C语言属于(B )语言 A)机器语言B)汇编语言C)高级语言D)面向对象语言 第二单元C语言基础 一、选择题 1、C语言中普通整型变量int在内存中占(B )字节。 A)1 B)2 C)3 D)4 2、下列不是C语言基本数据类型的是(A )。 A)字符型B) 整型 C) 浮点型D) 结构体 3、有关自增、自减运算,以下只有(D )是正确的。 A) ---f B) ++78 C) a—b++ D) d++ 4、已知A=7.5,B=2,C=3.6,表达式(A>B && C>A) || (AB)的值是(A )。 A)0 B)10 C)1 D)5

5、若有x=1,y=2,z=3,则表达式(x=‘A’)&(ch<=‘Z’) C) (ch>=‘A’)&&(ch<=‘Z’) D) (‘A’<= ch)AND(‘Z’>= ch) 7、判断整型变量digit是否为数字的正确表达式是(C )。 A) ‘0’<=ch<=‘9’B) (ch>=‘0’)&(ch<=‘9’) C) (ch>=‘0’)&&(ch<=‘9’) D) (‘0’<= ch)AND(‘9’>= ch) 8、一个C程序的执行是从(A )。 A)本程序的main函数开始,到main函数结柬 B)本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C)本程序的main函数开始,到本程序文件的最后一个函数结束 D)本程序文件的第一个函数开始,到本程序main函数结束 9、在以下标识符中,合法的是(C ) A)if B)0xy C)_xy D)case 10、C语言中各种类型的数据其实决定了占用内存的字节数。float占(C )。 A)一字节B)二字节C)四字节D)八字节 11、下列各选项中,(A )是有效的标识符。 A)ab B)3day C)day-3 D)#abc 12、以下叙述正确的是(C ) A) 在C程序中,每行只能写一条语句 B) 若a是实型变量,C程序中不允许a=10这种赋值。 C) 在C程序中,%是只能用于整数运算的运算符 D) 在C程序中,无论是整数还是实数,没有什么区别 13、有输入语句:scanf(“a=%d,b=%d,c=%d”,&a,&b,&c);为使变量a的值为1,b的值为3,c的值为2,则正确的数据输入方式是( B )。 A)132↙B)1,3,2↙ C)a=1 b=3 c=2↙D)a=1,b=3,c=2↙ 14、设整型变量a为5,使b不为2的表达式是( C )。 A)b = a/2 B)b = 6-(--a) C)b=a%2 D)b=a>3?2:1

相关主题
文本预览