标签: ,

测试试题:目前测试中共有15道单选题,15道判断题,10道简答题 ,已配置 100 分

一、选择题(共30分,每小题2分)

1.

在下面的函数声明语句中,存在着语法错误的是(    )。

单选题 (2 分) 2

AA(int a, int b)

AA(int, int)

AA(int a; int b)

AA(int a, int)

2.

在下面的保留字中,不能作为函数的返回值类型的是(    )。

单选题 (2 分) 2

void

int

enum

long

3.

假定p是一个指向float型数据的指针,则p+1所指数据的地址比p所指数据的地址增加的字节数为(    )。

单选题 (2 分) 2

1

2

4

8

4.

假定a为一个数组名,在下面的表达式中,存在语法错误的是(    )。

单选题 (2 分) 2

a[i]

*a++

*a

*(a+1)

5.

用calloc函数创建具有10个整型元素的一维数组的正确语句是(    )。

单选题 (2 分) 2

int *p=calloc(10,2);

int *p=calloc(10);

int *p=calloc(10,4);

int *p=malloc(10)

6.

假定变量m定义为“int m=7;”,则下面正确的语句为(    )。

单选题 (2 分) 2

int p=&m;

int *p=&m;

int &p=*m;

int *p=m;

7.

假定k是一个double类型的变量,则定义变量p的正确语句为(    )。

单选题 (2 分) 2

double p=&k;

int *p=&k;

 double &p=*k;

char *p=”Thank you!”;

8.

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

单选题 (2 分) 2

x=pa[3];

x=*(a+3);

x=a[3];

x=*pa+3;

9.

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

单选题 (2 分) 2

pb=b;

pb=&b[0];

pb=b+2;

pb=b[5];

10.

已知“int *p=malloc(100);”,要释放p所指向的动态内存,正确的语句为(    )。

单选题 (2 分) 2

free(p);

free p;

free(*p);

free[p];

11.

在程序的一个文件中定义的函数,若要在另一个文件中调用,则必须在这另一个文件中给出该函数的(    )。

单选题 (2 分) 2

原型语句

参数表

函数名

返回类型

12.

假定一个函数定义为“static int f1(int x,int y){return x+y;}”,该函数名称为(    )。

单选题 (2 分) 2

static

int

f1

return

13.

假定一个函数的原型语句为“int ff(int* x);”,一个整型数组为a[10],则下面函数调用表达式不正确的是(    )。

单选题 (2 分) 2

ff(a)

ff(a[0])

ff(a+3)

ff(&a[0])

14.

假定一个函数的数组参数说明为char a[],与之等价的指针参数说明为(    )。1B

单选题 (2 分) 2

char a

char* a

char& a

char**a

15.

假定一个函数的二维数组参数说明为char w[][N],与之等价的指针参数说明为(    )。

单选题 (2 分) 2

char (*w)[N]

char *w[N]

char (*w)N

char**a

二、判断题(共30分,每小题2分。叙述正确则回答“是”,否则回答“否”)

16.

在C语言中,一个函数由函数头和函数体组成。

判断题 (2 分) 2

17.

在函数模块之外定义的变量称为全局变量,若没有被初始化则系统隐含对它赋初值0。

判断题 (2 分) 2

18.

如果一个函数只允许同一程序文件中的函数调用,则不应在该函数定义的开始前加上保留字static。

判断题 (2 分) 2

19.

如果在一个函数体中又出现对自身函数的调用,此种函数调用被称为递归调用。

判断题 (2 分) 2

20.

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

判断题 (2 分) 2

21.

函数形参变量不属于局部变量。

判断题 (2 分) 2

22.

假定p所指对象的值为25,p+1所指对象的值为46,则*p++的值为46。

判断题 (2 分) 2

23.

假定p所指对象的值为25,p+1所指对象的值为46,则*++p的值为25。

判断题 (2 分) 2

24.

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

判断题 (2 分) 2

25.

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

判断题 (2 分) 2

26.

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

判断题 (2 分) 2

27.

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

判断题 (2 分) 2

28.

假定x为一个简单变量,则&x表示x的地址。

判断题 (2 分) 2

29.

若p指向x,则*p与x的值不同。

判断题 (2 分) 2

30.

NULL是一个符号常量,通常作为空指针值,它代表的值为0。

判断题 (2 分) 2

三、写出下列每个程序运行后的输出结果(共20分,每小题4分)

31.

#include<stdio.h>

       int WF(int x, int y) {

           x=x+y;

           y=x+y;

           return x+y;

       }

       void main() {

           int x=5, y=7;

           int z=WF(x,y);

           printf(“z=%d\n”,z);

       }

简答题 (4 分) 4

z=31

32.

 #include<stdio.h>

       #include<string.h>

       void fun(char ss[]);

       void main( ) {

           char s[15]=”0123456789″;

           fun(s);

           printf(“%s\n”,s);

       }

       void fun(char ss[]) {

           int i, n=strlen(ss) ;

           for(i=0; i<n/2; i++) {

               char c=ss[i];

               ss[i]=ss[n-1-i];

               ss[n-1-i]=c;

           }

       }

简答题 (4 分) 4

9876543210

33.

#include<stdio.h>

int Count(int a[], int n, int x)

{

int i,c=0;

for(i=0;i<n;i++)

if(a[i]>x) c++;

return c;

}

void main() {

int a[8]={20,15,32,47,24,36,28,70};

int b=Count(a,8,30);

printf(“b=%d\n”,b);

}

简答题 (4 分) 4
34.

#include<stdio.h>

       void main() {

           int a[8]={3,5,7,9,2,3,4,8};

           int s=0,*p;

           for(p=a;p<a+8;) s+=*p++;

           printf(“s=%d\n”,s);

       }

简答题 (4 分) 4

s=41

35.

#include<stdio.h>

       int LA(int *a, int n, int x) {

           int i,s=0;

           for(i=0;i<n;i++)

               if(a[i]<x) s+=a[i];

           return s;

       }

       void main() {

           int a[8]={5,10,15,8,12,3,9,20};

           int b=LA(a,5,10);

           int c=LA(a+2,6,10);

           printf(“%d %d\n”,b,c);

       }

简答题 (4 分) 3

1320

四、写出下列每个函数的功能(共20分,每小题4分)

36.

double SF(double x, int n) {  //n为正整数

           double p=1,s=1;

           int i;

           for(i=1;i<=n;i++) {

               p*=x;

               s+=p;

           }

           return s;

       }

简答题 (4 分) 4

计算出1+x+x2+…+xn的值并返回。

37.

int SG(int x) {            //x为大于等于2的整数

           int i=2;

           while(i*i<=x) {

               if(x%i==0) break;

               i++;

           }

           if(i*i<=x) return 0; else return 1;

       }

简答题 (4 分) 4

判断x是否为一个质数(素数),若是则返回1,否则返回0。

38.

int WB(int a[], int n, int x) {

          for(int i=0;i<n;i++)

              if(a[i]==x) return 1;

          return 0;

       }

简答题 (4 分) 4

从数组a[n]中顺序查找值为x的元素,若查找成功则返回1,否则返回0。

39.

int fun(int m, int n) {

           int c=0;

           static int b=2;

           if(m<b || n<b) return m*n;

           else if(m%b==0 && n%b==0) {c=b; return c*fun(m/b,n/b);}

           else {b++; return fun(m,n);}

       }

简答题 (4 分) 4

一个递归函数过程,求出两个自然数m和n的最小公倍数。

40.

int LK(double a[], int n) {

           double s=0;

           int i,m=0;

           for(i=0;i<n;i++) s+=a[i];

           s/=n;

           for(i=0;i<n;i++)

               if(a[i]>=s) m++;

           return m;

       }

简答题 (4 分) 4

求出并返回数组a的n个元素中大于等于平均值的元素个数。