文档介绍:该【算法与数据结构—C语言描述及参考答案 】是由【1130474171@qq.com】上传分享,文档一共【13】页,该文档可以免费在线阅读,需要了解更多关于【算法与数据结构—C语言描述及参考答案 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。算法与数据结构—C语言描述
第一部分 单选题(50题)
1、以下哪个for循环是无限循环?( )
(i=0;i<5;i++)
(;;)
(i=0;i<5;i--);
(i=5;i>0;i--)
【答案】:答案解析:for循环三个表达式均省略时,条件恒为真,是无限循环,A执行5次,C、D初始条件不满足(执行0次),故选B。
2、若inti=0,s=0;执行for(i=0;i<4;i++)s+=i;后s的值是?( )
【答案】:答案解析:累加0+1+2+3=6,s=6,故选A。
3、若inta[3][3]={{1,2},{3,4},{5,6}};则a[1][1]的值是?( )
【答案】:答案解析:a[1][1]是第二行第二列,值为4,故选B。
4、若intx=3;执行以下代码后a的值是?( )inta;if(x>5)a=10;elseif(x>2)a=20;elsea=30;
【答案】:答案解析:x=3>2,执行第二个分支,a=20,故选B。
5、以下数组定义错误的是?( )
[5];
[5]={1,2,3,4,5};
[5]={1,2,3,4,5,6};
[]={1,2,3,4,5};
【答案】:答案解析:C初始化元素超5个,编译报错,其余正确,故选C。
6、以下指针运算正确的是?( )
=10,*p=&a;p++;
=10,*p=&a;p=a;
=10,*p=&a;p=&5;
=10,*p=&a;*p=&a;
【答案】:答案解析:A指针p自增(指向a的下一个地址),B不能将int值赋给指针,C不能取常量地址,D不能将地址赋给int变量,故选A。
7、以下for循环中,用于计算1到5的平方和的是?( )
=0;for(i=1;i<=5;i++)s+=ii;
=0;for(i=1;i<=5;i++)s+=i2;
=1;for(i=1;i<=5;i++)s*=i;
=0;for(i=1;i<=5;i++)s+=i+i;
【答案】:答案解析:平方和是1²+2²+3²+4²+5²=1+4+9+16+25=55,A的逻辑正确,故选A。
8、若inti=1,s=0;执行while(i<=5){s+=i;i++;}后s的值是?( )
【答案】:答案解析:循环累加1+2+3+4+5=15,s=15,故选A。
9、以下函数递归调用的例子是?( )
【答案】:答案解析:阶乘常用递归实现(n!=n*(n-1)!),B、C、D用循环更高效,故选A。
10、以下函数调用错误的是?( )
();
(5);
(3,4);
(需看函数定义)
【答案】:答案解析:调用需匹配函数定义,A对应无参函数,B对应单参函数,C对应双参函数,均可能正确,故选D。
11、以下switch语句中,default的作用是?( )
【答案】:答案解析:default用于匹配所有case未覆盖的情况,可选且位置灵活,故选B。
12、以下关于数组的说法正确的是?( )
【答案】:答案解析:A数组长度定义后固定,B元素必须同类型,D数组名是常量(不可赋值),C正确,故选C。
13、若inta[3][3]={{1,2,3},{4,5,6},{7,8,9}},(p)[3]=a;则((p+1)+2)的值是?( )
【答案】:答案解析:p是指向3列数组的指针,p+1指向第二行,(p+1)+2指向第二行第三列,值为6,故选B。
14、以下关于指针的说法错误的是?( )
、数组、函数
(如++、--)
【答案】:答案解析:指针不能指向自身(类型不匹配),A、B、D说法正确,故选C。
15、若intx=10;则表达式x%3的结果是?( )
【答案】:答案解析:%是取余运算符,10除以3商3余1,故选A。
16、以下switch语句中,default的位置可以在?( )
【答案】:答案解析:default位置灵活,可在case前、后或中间,不影响执行逻辑,故选D。
17、continue语句只能用于以下哪种结构?( )
【答案】:答案解析:continue仅用于循环语句(for/while/do-while),用于跳过本次循环,故选A。
18、以下if语句中,赋值表达式作为条件的是?( )
(x==3)
(x=3)
(x>3)
(x!=3)
【答案】:答案解析:x=3是赋值表达式,结果为3(非0,真),其余是判断表达式,故选B。
19、数组名作为函数参数时,传递的是?( )
【答案】:答案解析:数组名传参本质是首元素地址(指针传递),函数中可通过指针访问数组,故选C。
20、若inti=0;执行do{i++;printf("%d",i);}while(i<3);输出结果是?( )
【答案】:答案解析:do-while先执行,i从1到3,输出123,故选A。
21、若inta[5]={1,2,3};则a[3]的值是?( )
【答案】:答案解析:初始化时未赋值的元素默认为0,a[3]=0,故选A。
22、逻辑表达式3&&0的结果是?( )
【答案】:答案解析:逻辑与&&只要有一个operand为0则结果为0,3为真,0为假,故选A。
23、若charstr[]="helloworld";则字符串长度是?( )
【答案】:答案解析:"helloworld"含11个字符(不含\0),长度为11,故选B。
24、以下函数返回值类型为int的是?( )
(){return;}
(){;}
(){return5;}
(){return'a';}
【答案】:答案解析:A返回值类型void(不能return表达式),B返回类型int(),C返回类型float,D返回类型char,故选B。
25、若intx=5;则表达式x+++x的结果是?( )
【答案】:答案解析:结合性从左到右,x+++x等价于(x++)+x=5+6=11,故选B。
26、以下函数定义正确的是?( )
(){printf("hello");}
(inta){printf("%d",a);}
(){return5;}
【答案】:答案解析:A无参无返回值,B有参无返回值,C无参有返回值,均符合语法,故选D。
27、以下关于二维数组的说法正确的是?( )
【答案】:答案解析:二维数组本质是数组的数组,内存按行存储,可作为函数参数,长度需常量,故选A。
28、若inti=5,s=0;执行while(i>0){s+=i;i--;}后s的值是?( )
【答案】:答案解析:累加5+4+3+2+1=15,s=15,故选A。
29、以下关于return语句的说法正确的是?( )
【答案】:答案解析:A函数中可有多条return(如条件判断后返回),Bvoid函数可无return,Creturn可在任意位置,Dreturn只能返回一个值(返回多个值需用指针/数组),故选A。
30、若intx=3,y=5;则表达式x>y?x:y的结果是?( )
【答案】:答案解析:三元运算符格式“条件?值1:值2”,x>y为假,取y=5,故选B。
31、以下循环语句中,执行次数为5次的是?( )
(i=0;i<5;i++)
(i<5){i++;}
{i++;}while(i<5);
(i=1;i<=5;i--)
【答案】:答案解析:A执行5次(0-4),B、C未初始化i(若i初始0则5次,否则不确定),D初始i=1>0,执行0次,故选A。
32、若inti=0;执行while(i<5){i++;if(i==3)continue;printf("%d",i);}输出结果是?( )
【答案】:答案解析:i=3时continue,跳过printf,输出1、2、4、5,故选A。
33、若inta[3][3]={{1,2,3},{4,5,6},{7,8,9}};则a[1][2]的值是?( )
【答案】:答案解析:a[1][2]是第二行第三列,值为6,故选B。
34、若inta=3;执行if(++a==4)printf("A");elseprintf("B");输出结果是?( )
【答案】:答案解析:++a使a=4,条件为真,输出A,故选A。
35、函数参数传递中,值传递适用于?( )
,无需修改实参
,需修改元素
,需修改实参
,需修改成员
【答案】:答案解析:值传递用于简单变量(不修改实参),地址传递用于需修改实参的场景,故选A。
36、以下函数参数为指针的是?( )
(int*a){}
(inta){}
(inta[]){}
【答案】:答案解析:A是指针参数,C数组名参数本质是指针,B是值参数,故选D。
37、以下函数定义中,参数为指针的是?( )
(int*a){printf("%d",*a);}
(inta){printf("%d",a);}
(inta[]){printf("%d",a[0]);}
【答案】:答案解析:A是指针参数,C数组名参数本质是指针,B是值参数,故选D。
38、函数调用时,实参和形参的个数必须?( )
【答案】:答案解析:函数调用时实参和形参个数、类型需匹配,否则编译错误,故选A。
39、若inti=1;执行do{printf("%d",i);i++;}while(i<=0);输出结果是?( )
【答案】:答案解析:do-while先执行一次(输出1,i=2),再判断i<=0为假,循环结束,故选A。
40、若floatx=;则表达式(int)x的结果是?( )
【答案】:答案解析:强制转换为int取整数部分,→3,故选A。