C语言笔试题及答案.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

C语言笔试题及答案

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

以下关于C语言变量声明的说法,正确的是()

A.变量声明必须在函数开头

B.同一作用域内,同名变量可以多次声明但只能定义一次

C.externinta;是变量定义语句

D.局部变量未初始化时,默认值为0

若有定义inta[5]={1,2,3};,则以下说法错误的是()

A.a[3]的值为0

B.数组名a本质是指向数组首元素的常量指针

C.sizeof(a)的结果为20(32位系统)

D.可以通过a++移动数组指针

关于指针操作,以下代码运行结果是()

#includestdio.h

intmain(){

intx=10,*p=x,**pp=p;

printf(%d,**pp+*p+x);

return0;

}

A.10B.20C.30D.编译错误

以下关于函数递归的说法,错误的是()

A.递归必须有终止条件

B.递归调用会占用栈空间,可能导致栈溢出

C.所有递归问题都可以用循环实现

D.递归效率通常比循环高

若有宏定义#defineMAX(a,b)((a)(b)?(a):(b)),执行intx=3,y=4,z=MAX(x++,y++);后,x、y、z的值分别是()

A.4,5,4B.4,5,5C.3,4,4D.3,4,5

关于C语言内存分区,以下说法正确的是()

A.局部变量存储在堆区

B.全局变量存储在静态区

C.malloc分配的内存存储在栈区

D.字符串常量存储在栈区

二、填空题(每题5分,共20分)

若有定义inta=6,b=4;,则表达式a+=b*=2的结果是________。

以下代码的运行结果是________。

#includestdio.h

voidfun(int*a,int*b){

inttemp=*a;

*a=*b;

*b=temp;

}

intmain(){

intx=1,y=2;

fun(x,y);

printf(%d%d,x,y);

return0;

}

用指针遍历数组intarr[5]={10,20,30,40,50},输出所有元素的循环语句可写为:

int*p=arr;

for(;parr+5;________){

printf(%d,*p);

}

以下代码实现计算1到n的阶乘,填空补充完整:

intfactorial(intn){

if(n==1)________;

returnn*factorial(n-1);

}

三、编程题(每题25分,共50分)

编写一个函数,判断一个整数是否为素数(质数),主函数输入一个整数,调用该函数并输出判断结果。

编写程序,实现将一个字符串中的大写字母转换为小写字母,小写字母保持不变,其他字符原样输出(要求用指针实现)。

答案及解析

一、选择题

B

解析:A选项错误,C99标准后变量声明可在代码块任意位置;C选项错误,extern仅声明变量,不分配内存(定义需赋值或省略extern);D选项错误,局部变量未初始化时值为随机数,全局变量和静态变量默认值为0。

D

解析:数组名是常量指针,不能进行自增自减操作(a++非法);A选项未初始化的数组元素默认值为0;C选项32位系统int占4字节,5个元素共20字节。

C

解析:p指向x,pp指向p,**pp等价于*x,故计算为10+10+10=30。

D

解析:递归调用需多次压栈,效率低于循环,且递归深度过大会导致栈溢出。

B

解析:宏替换为((x++)(y++)?(x++):(y++)),先执行x++(x=3→4)、y++(y=4→5),比较45为假,执行y++(y=5→6),最终z=5,x=4,y=6???修正:原宏替换后是((3++)(4++)?(3++):(4++)),第一次x++后x=4,y++后y=5,比较45为假,执行y++(y=5→6),故z=5,最终x=4,y=6???正确解析:宏是直接替换,执行过程:

先计算y++两次?不,宏替换后表达式为x+=(y*=2)→先算y*=2(y=4→8),再a+=8(a=6+8=14),答案14。

B

解析:局部变量存栈区(A错),malloc分配存堆区(C错),字符串

文档评论(0)

151****9429 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档