您好,欢迎来到年旅网。
搜索
您的当前位置:首页C语言程序设计形考任务3 (2)

C语言程序设计形考任务3 (2)

来源:年旅网
一、选择题(共30分,每题2分)

题目1

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

a. AA(int a, int b) b. AA(int, int) c. AA(int a; int b) d. AA(int a, int) 正确答案是:AA(int a; int b)

题目2

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

a. void b. int c. enum d. long 正确答案是:enum

题目3

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

a. 1

b. 2 c. 4 d. 8 正确答案是:4

题目4

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

a. a[i] b. *a++ c. *a d. *(a+1) 正确答案是:*a++

题目5

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

a. int *p=calloc(10,2); b. int *p=calloc(10); c. int *p=calloc(10,4); d. int *p=malloc(10) 正确答案是:int *p=calloc(10,4);

题目6

假定变量m概念为“int m=7;”,那么下面正确的语句为( )。选择一项:

a. int p=&m;

)。)。 b. int *p=&m; c. int &p=*m; d. int *p=m; 正确答案是:int *p=&m;

题目7

假定k是一个double类型的变量,那么概念变量p的正确语句为( )。 选择一项:

a. double p=&k; b. int *p=&k; c. double &p=*k;

d. char *p=\"Thank you!\"; 正确答案是:char *p=\"Thank you!\";

题目8

如有语句为“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; 正确答案是:x=*pa+3;

题目9

假定有语句为“int b[10]; int *pb;”,那么下面不正确的赋值语句为( )。 选择一项:

a. pb=b;

b. pb=&b[0]; c. pb=b+2; d. pb=b[5]; 正确答案是:pb=b[5];

题目10

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

a. free(p); b. free p; c. free(*p); d. free[p]; 正确答案是:free(p);

题目11

在程序的一个文件中概念的函数,假设要在另一个文件中挪用,那么必需在这另一个文件中给出该函数的( )。 选择一项:

a. 原型语句 b. 参数表 c. 函数名 d. 返回类型 正确答案是:原型语句

题目12

假定一个函数概念为“static int f1(int x,int y){return x+y;}”,该函数名称为( )。 选择一项:

a. static

b. int c. f1 d. return 正确答案是:f1

题目13

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

a. ff(a) b. ff(a[0]) c. ff(a+3) d. ff(&a[0]) 正确答案是:ff(a[0])

题目14

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

a. char a b. char* a c. char& a d. char**a 正确答案是:char* a

题目15

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

a. char (*w)[N]

b. char *w[N] c. char (*w)N d. char**a

正确答案是:char (*w)[N]

二、判定题(共30分,每题2分。表达正确那么回答“是”,不然回答“否”)

题目16

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

对 错

正确的答案是“对”。

题目17

在函数模块之外概念的变量称为全局变量,假设没有被初始化那么系统隐含对它赋初值0。 选择一项:

对 错

正确的答案是“对”。

题目18

假设是一个函数只许诺同一程序文件中的函数挪用,那么不该在该函数概念的开始前加上保留字static。 选择一项:

对 错

正确的答案是“错”。

题目19

假设是在一个函数体中又显现对自身函数的挪用,此种函数挪用被称为递归挪用。 选择一项:

对 错

正确的答案是“对”。

题目20

挪用系统函数时,要先利用#include命令包括该系统函数的原型语句所在的系统头文件。 选择一项:

对 错

正确的答案是“对”。

题目21

函数形参变量不属于局部变量。 选择一项:

对 错

正确的答案是“错”。

题目22

假定p所指对象的值为25,p+1所指对象的值为46,那么*p++的值为46。 选择一项:

对 错

正确的答案是“错”。

题目23

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

选择一项:

对 错

正确的答案是“错”。

题目24

假定p所指对象的值为25,p+1所指对象的值为46,那么执行*(p++)运算后,p所指对象的值为46。 选择一项:

对 错

正确的答案是“对”。

题目25

假定a是一个指针数组,那么a+i所指对象的地址比a地址大4*i字节。 选择一项:

对 错

正确的答案是“对”。

题目26

假设要把一个整型指针p转换为字符指针,那么采纳的强制转换表达式为(char*)p。 选择一项:

对 错

正确的答案是“对”。

题目27

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

选择一项:

对 错

正确的答案是“错”。

题目28

假定x为一个简单变量,那么&x表示x的地址。 选择一项:

对 错

正确的答案是“对”。

题目29

假设p指向x,那么*p与x的值不同。 选择一项:

对 错

正确的答案是“错”。

题目30

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

对 错

正确的答案是“对”。 信息文本

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

题目31

#include<>

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=31

题目32

#include<>

#include<>

void fun(char ss[]); void main( ) {

char s[15]=\"09\"; fun(s);

printf(\"%s\\n\ }

void fun(char ss[]) {

int i, n=strlen(ss) ; for(i=0; iss[i]=ss[n-1-i]; ss[n-1-i]=c; } } 10

题目33

#include<>

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

int i,c=0; for(i=0;ix) 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

题目34

#include<>

void main() {

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

int s=0,*p;

for(p=a;p题目35

#include<>

int LA(int *a, int n, int x) { int i,s=0; for(i=0;iif(a[i]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\ } 13 20

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

题目36

double SF(double x, int n) { .+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; }

判定x是不是为一个质数(素数),假设是那么返回1,不然返回0。

题目38

int WB(int a[], int n, int x) { for(int i=0;iif(a[i]==x) return 1; return 0; }

从数组a[n]中顺序查找值为x的元素,假设查找成功那么返回1,不然返回0。

题目39

int fun(int m, int n) { int c=0; static int b=2;

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

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

题目40

int LK(double a[], int n) { double s=0; int i,m=0;

for(i=0;ifor(i=0;iif(a[i]>=s) m++; return m; }

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

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- oldu.cn 版权所有 浙ICP备2024123271号-1

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务