2023年c语言模拟试题答案优质
范文为教学中作为模范的文章,也常常用来指写作的模板。常常用于文秘写作的参考,也可以作为演讲材料编写前的参考。相信许多人会觉得范文很难写?下面是小编为大家收集的优秀范文,供大家参考借鉴,希望可以帮助到有需要的朋友。
c语言模拟试题答案篇一
int a[12]={1,4,7,10,2,5,8,11,3,6,9,12};
a、10
b、9
c、6
d、5
先算a[a[i]]内层的a[i],由于i=10,因此a[i]即a[10].
a[10]对应下面数组中的元素为9. 因此a[a[i]]即为a[9]
a[9]对应下面数组中的元素为6. 因此a[9]即为6
2.若有说明:int a[][3]={{1,2,3},{4,5},{6,7}}; 则数组a的第一维的大小为: ( b )
a、2
b、3
c、4
d、3 6 9
二维数组的一维大小,即指二维数组的行数,在本题中,按行对二维数组赋值,因此内层有几个大括号,数组就有几行
3.对二维数组的正确定义是(c)
详见教材p149~152,二维数组的定义、初始化
类型符 数组名 [常量表达式][常量表达式]
二维数组可以看做是矩阵
类型符是指数组中数组元素的类型;数组名要符合标识符命名规则;第一个常量表达式是指数组的行数;第二个常量表达式是指数组的列数;常量表达式的值只能是整数,不可以是变量,而且从1开始计数。
一维数组初始化时可以省略数组长度
二维数组初始化时可以省略行数,但不能省略列数
选项a,b,都省略了列数
选项d,不符合二维数组定义的一般形式,行、列常量表达式应该放在不同的[]中
a、int a[ ][ ]={1,2,3,4,5,6};
b、int a[2] []={1,2,3,4,5,6};
c、int a[ ] [3]={1,2,3,4,5,6};
d、int a[2,3]={1,2,3,4,5,6};
4.已知int a[3][4];则对数组元素引用正确的是__c___
a、a[2][4]
b、a[1,3]
c、a[2][0]
d、a(2)(1)
5.c语言中函数返回值的类型是由 a 决定的.
a、函数定义时指定的类型
b、 return语句中的表达式类型
c、 调用该函数时的实参的数据类型
d、形参的数据类型
6. 在c语言中,函数的数据类型是指(a )
a、 函数返回值的数据类型
b、 函数形参的数据类型
c、 调用该函数时的实参的数据类型
d、任意指定的数据类型
7.在函数调用时,以下说法正确的是( b)
a、函数调用后必须带回返回值
b、实际参数和形式参数可以同名
c、函数间的数据传递不可以使用全局变量
d、主调函数和被调函数总是在同一个文件里
8. 在c语言中,表示静态存储类别的关键字是: ( c )
a、 auto
b、 register
c、static
d、extern
9.未指定存储类别的变量,其隐含的存储类别为(a )。
a、auto
b、static
c、extern
d、register
10. 若有以下说明语句:
struct student
{ int num;
char name[ ];
float score;
}stu;
则下面的叙述不正确的是: (d )
a、 struct是结构体类型的关键字
b、 struct student 是用户定义的结构体类型
c、 num, score都是结构体成员名
d、 stu是用户定义的结构体类型名
11.若有以下说明语句:
struct date
{ int year;
int month;
int day;
}brithday;
则下面的叙述不正确的是__c___.
a、 struct是声明结构体类型时用的关键字
b、 struct date 是用户定义的结构体类型名
c、 brithday是用户定义的结构体类型名
d、year,day 都是结构体成员名
12. 以下对结构变量stul中成员age的非法引用是 b
struct student
{ int age;
int num;
}stu1,*p;
p=&stu1;
a、
b、
c、 p->age
d、(*p).age
13.设有如下定义:
struck sk
{ int a;
float b;
}data;
int *p;
若要使p指向data中的a域,正确的赋值语句是 c
a、 p=&a;
b、 p=data、a;
c、p=&data、a;
d、*p=data、a;
14.设有以下说明语句:
typedef struct stu
{ int a;
float b;
} stutype;
则下面叙述中错误的是( d )。
a、struct是结构类型的关键字
b、struct stu是用户定义的结构类型
c、a和b都是结构成员名
d、stutype是用户定义的结构体变量名
15.语句int *p;说明了 c 。
a、p是指向一维数组的指针
b、p是指向函数的指针,该函数返回一int型数据
c、p是指向int型数据的指针
d、p是函数名,该函数返回一指向int型数据的指针
16、以下语句的输出结果是(d)。
int a=-1,b=4,k;
k=(+ +a<0)&&!(b - -<=0);
printf("%d,%d,%d ",k,a,b);
a. 1,0,4
b. 1,0,3
c. 0,0,3
d. 0,0,4
17、下列程序的输出结果是(d)。
char *p1="abcd", *p2="abcd", str[50]="xyz";
strcpy(str+2,strcat(p1+2,p2+1));
printf("%s",str);
a. xyabcab
b. abcabz
c. ababcz
d. xycdbcd
18、执行下面的程序后,a的值是(b)。
define sqr(x) x*x
main()
{ int a=10,k=2,m=1;
a/=sqr(k+m)/sqr(k+m);
printf("%d ",a); }
a. 10
b. 1
c. 9
d. 0
19、设a为存放(短)整型的一维数组,如果a的首地址为p,那么a中第i 个元素的地址为(b)。
a.p+i*2
b. p+(i-1)*2
c. p+(i-1)
d. p+i
20、下列程序执行后输出的结果是(a)。
int d=1;
fun (int p)
{ int d=5;
d + =p + +;
printf("%d,",d); }
main()
{ int a=3;
fun(a);
d + = a + +;
printf("%d ",d); }
a. 8, 4
b. 9, 6
c. 9, 4
d. 8, 5
21、表达式:10!=9的值是(d)。
a. true
b. 非零值
c. 0
d. 1
22、若有说明: int i,j=7, *p=&i;, 则与i=j; 等价的语句是(b)。
a. i= *p;
b. *p=*&j;
c. i=&j;
d. i=* *p;
23、不能把字符串:hello!赋给数组b的语句是(b)。
a. char b[10]={’h’,’e’,’l’,’l’,’o’,’!’};
b. char b[10]; b="hello!";
c. char b[10]; strcpy(b,"hello!");
b[10]="hello!";
24、在c程序中有如下语句:char *func(int x,int y); 它是(c)。
a. 对函数func的定义。
b. 对函数func的.调用。
c.对函数func的原型说明。
d. 不合法的。
25、以下程序的输出结果是(d)。
char str[15]=”hello!”;
printf(“%d ”,strlen(str));
a. 15
b. 14
c. 7
d. 6
26[单选题] 以下叙述中正确的是()
a.用户自己定义的函数只能调用库函数
b.实用的c语言源程序总是由一个或多个函数组成
c.不同函数的形式参数不能使用相同名称的标识符
d.在c语言的函数内部,可以定义局部嵌套函数
参考答案:b
参考解析:a选项中,”用户自己定义的函数只能调用库函数”描述是不正确的,也可以调用自定义函数;c选项中,对于不同函数的形式参数可以使用相同名称的标识符;d选项中,关于函数的定义不可以嵌套,但函数的调用可以嵌套。因此b选项正确。
27[单选题] 以下关于c语言数据类型使用的叙述中错误的是( )。
a.若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型
b.若要保存带有多位小数的数据,可使用双精度类型
c.若只处理“真”和“假”两种逻辑值,应使用逻辑类型
d.整数类型表示的自然数是准确无误差的
参考答案:c
参考解析:c语言中没有逻辑类型,所以c错误。若要保存带有多位小数的数据,可以用单精度类型也可以用双精度类型。处理包含不同类型的相关数据可以定义为结构体类型。整数类型可以无误差的表示自然数。
28[单选题] 下面选项中关于编译预处理的叙述正确的是
a.预处理命令行必须使用分号结尾
b.凡是以#号开头的行,都被称为编译预处理命令行
c.预处理命令行不能出现在程序的最后一行
d.预处理命令行的作用域是到最近的函数结束处
参考答案:b
参考解析:本题考查预编译的预编译处理命令行,预处理命令行不能以分号结尾,所以a选项错误,预处理命令行可以出现在程序的最后一行,预处理命令行作用域是整个文件。
29[单选题] 有以下程序
程序的输出结果是
a.0b.1c.9d.10
参考答案:b
参考解析:本题考查宏定义,宏定义只是做个简单的替换。执行sqr(k+m)/sqr(k+m)=k+m*k+m/k+m}k+m=15/2,a/=sqr(k+m)/sqr(k+1ti)的结果为1,选项b正确。
30[单选题] 设--x树共有150个结点,其中度为l的结点有l0个,则该---x树中的叶子结点数为( )。
a.71b.70c.69d.不可能有这样的二叉树
参考答案:d
参考解析:在树结构中,一个结点所拥有的后件个数称为该结点的度,所有结点中最大的度称为树的度。对任何一棵二叉树,度为0的结点总是比度为2的结点多一个。如果有一棵二叉树,结点总数为l50,假设度为0的结点个数为n,则有n+10+n一1=150,n=70.5,由于结点个数必须是整数,所以不可能有题目中这样的二叉树。故选择d选项。
31[单选题] 有以下程序:
程序运行后的输出结果是( )。
a.2.3b.1,3c.1,4d.1,2
参考答案:b
参考解析:在f(int+p,int 4 q)函数中,执行p=p+1是将p所对应的地址加1,而0 q=+q+1是将q所指向的n的地址所对应的值加1,所以m的得知所对应的值没有变,而n的值则为3了。因此b选项正确。
32[单选题] 以下选项中,能用作用户标识符的是( )。
a.-0-b.8-;ed
参考答案:a
参考解析:c语言中标识符由字母、下划线、数字组成,且开头必须是字母或下划线。另外,关键字不能作为标识符。8中以数字8开头,所以错误。c与d中用的是关键字void与unsigned,所以错误。
33[单选题] 以下叙述正确的是( )。
a.表达式sizeof(file*)==sizeof(int*)的值为真
b.文件指针的值是一个整数,它的值一定小于文件字节数
c.文件指针的值是所指文件的当前读取位置
d.使用fscanf函数可以向任意类型的文件中写入任意数量的字符
参考答案:a
参考解析:
slzeof(file})=4,因为file·为指针,指针的大小4,sizeof(int·)=4,理由同前面。文件指针的值是地址,是一个16进制的数,它的值不一定小于文件字节数,因此选项8错误。文件指针是所指文件的当前读取位置,而不是文件指针的值因此选项c错误。mgscanf(file-stream,constchar}format,[argument…]fmanf函数可以向任意类型的文件,写入任意数量不能超过系统的缓冲区,写文件先写入缓冲区,最后一起写入文件,因此选项d错误。答案为a选项。