收藏 分销(赏)

2023年9月全国计算机二级C语言笔试试题答案.doc

上传人:二*** 文档编号:4516222 上传时间:2024-09-26 格式:DOC 页数:21 大小:42.04KB
下载 相关 举报
2023年9月全国计算机二级C语言笔试试题答案.doc_第1页
第1页 / 共21页
本文档共21页,全文阅读请下载到手机保存,查看更方便
资源描述
一、选择题((1)-(10),(21)-(40)每题2分,(11)-(20)每题1分,共70分)   下列各题A)、B)、C)、D)四个选项中,只有一个选项是对的的。请将对的选项填涂在答题卡相应位置上,答在试卷上不得分。 1. 下列叙述中对的的是 A 线性表的链式存储结构与顺序存储结构所需要的存储空间是相同的 B 线性表的链式存储结构所需要的存储空间一般要多于顺序存储结构 C 线性表的链式存储结构所需要的存储空间一般要少于顺序存储结构 D 上述三种说法都不对 答案:B 2. 下列叙述中对的的是 A 在栈中,栈中元素随栈底指针与栈顶指针的变化而动态变化 B 在栈中,栈顶指针不变,栈中元素随栈底指针的变化而动态变化 C 在栈中,栈底指针不变,栈中元素随栈顶指针的变化而动态变化 D 上述三种说法都不对 答案:C 3. 软件测试的目的是 A 评估软件可靠性 B 发现并改正程序中的错误 C 改正程序中的错误 D 发现程序中的错误 答案:B 4. 下面描述中,不属于软件危机表现的是 A 软件过程不规范 B 软件开发生产率低 C 软件质量难以控制 D 软件成本不断提高 答案:A 5. 软件生命周期是指 A 软件产品从提出、实现、使用维护到停止使用退役的过程 B 软件从需求分析、设计、实现到测试完毕的过程 C 软件的开发过程 D 软件的运营维护过程 答案:A 6. 面向对象方法中,继承是指 A 一组对象所具有的相似性质 B 一个对象具有另一个对象的性质 C 各对象之间的共同性质 D 类之间共享属性和操作的机制 答案:D 7. 层次型、网状型和关系型数据库划分原则是 A 记录长度 B 文献的大小 C 联系的复杂限度 D 数据之间的联系方式 答案:D 8. 一个工作人员可以使用多台计算机,而一台计算机可被多个人使用,则实体工作人员、与实体计算机之间的联系是 A 一对一 B 一对多 C 多对多 D 多对一 答案:C 9. 数据库设计中反映用户对数据规定的模式是 A 内模式 B 概念模式 C 外模式 D 设计模式 答案:C 10. 有三个关系R、S和T如下: 则由关系R和S得到关系T的操作是 A 自然连接 B 交 C 投影 D 并 答案:A 11. 以下关于结构化程序设计的叙述中对的的是 A 一个结构化程序必须同时由顺序、分支、循环三种结构组成 B 结构化程序使用goto语句会很便捷 C 在C语言中,程序的模块化是运用函数实现的 D 由三种基本结构构成的程序只能解决小规模的问题 答案:C 12. 以下关于简朴程序设计的环节和顺序的说法中对的的是 A 拟定算法后,整理并写出文档,最后进行编码和上机调试 B 一方面拟定数据结构,然后拟定算法,再编码,并上机调试,最后整理文档 C 先编码和上机调试,在编码过程中拟定算法和数据结构,最后整理文档 D 先写好文档,再根据文档进行编码和上机调试,最后拟定算法和数据结构 答案:D 13. 以下叙述中错误的是 A C程序在运营过程中所有计算都以二进制方式进行 B C程序在运营过程中所有计算都以十进制方式进行 C 所有C程序都需要编译链接无误后才干运营 D C程序中整型变量只能存放整数,实型变量只能存放浮点数 答案:B 14. 有以下定义:inta; longb; doublex,y;则以下选项中对的的表达式是 A a%(int)(x-y) B a=x!=y; C (a*y)%b D y=x+y=x 答案:C 15. 以下选项中能表达合法常量的是 A 整数:1,200 B 实数:1.5E2.0 C 字符斜杠:‘\’ D 字符串:"\007" 答案:C 16. 表达式a+=a-=a=9的值是 A 9 B _9 C 18 D 0 答案:D 17. 若变量已对的定义,在if (W)printf(“%d\n,k”);中,以下不可替代W的是 A a<>b+c B ch=getchar() C a==b+c D a++ 答案:A 18. 有以下程序   #include   main()   {inta=1,b=0;   if(!a) b++;   elseif(a==0)if(a)b+=2;   elseb+=3;   printf(”%d\n”,b);   }   程序运营后的输出结果是 A 0 B 1 C 2 D 3 答案:C 19. 若有定义语句int a, b;double x;则下列选项中没有错误的是 A B C D 答案:C 20. 有以下程序   #include   main()   {int a=1,b=2;   while(a<6){b+=a;a+=2;b%二10;}   printf(”%d,%d\n”,a,b);   }   程序运营后的输出结果是 A 5,11 B 7,1 C 7,11 D 6,1 答案:D 21. 有以下程序   #include<stdio.h>   main()   {int y=10;   while(y--);   printf(”Y=%d\n”,Y);   }   程序执行后的输出结果是 A y=0 B y= -1 C y=1 D while构成无限循环 答案:B 22. 有以下程序   #include<stdio .h>   main()   {char s[」=”rstuv";   printf(”%c\n”,*s+2);   }   程序运营后的输出结果是 A tuv B 字符t的ASCII码值 C t D 犯错 答案:D 23. 有以下程序   #include<stdio.h>   #include<string.h>   main()   {char x[]=”STRING”;   x[0」=0;x[1]=’\0’;x[2」=’0’;   printf(”%d%d\n”,sizeof(x),strlen(x));   }   程序运营后的输出结果是 A 61 B 70 C 63 D 71 答案:B 24. 有以下程序   #include<stdio.h>   Int f(intx);   main()   {intn=1,m;   m=f(f(f(n)));printf(”%d\n”,m);   }   intf(intx)   {returnx*2;}   程序运营后的输出结果是 A 1 B 2 C 4 D 8 答案:D 25. 以下程序段完全对的的是 A int *p;scanf("%d",&p); B int *p;scanf(“%d”,p); C int k, *p=&k;scanf("%d",p); D int k, *p:;*p= &k; scanf(“%d”,p); 答案:D 26. 有定义语句:int *p[4];以下选项中与此语句等价的是 A intp[4]; B int**p; C int*(p「4」); D int (*p)「4」; 答案:D 27. 下列定义数组的语句中,对的的是 A B C intx[0..10]; D int x[]; 答案:B 28. 若要定义一个具有5个元素的整型数组,以下错误的定义语句是 A inta[5]=﹛0﹜; B intb[]={0,0,0,0,0}; C intc[2+3]; D inti=5,d[i]; 答案:A 29. 有以下程序   #include<stdio.h>   voidf(int *p);   main()   {inta[5]={1,2,3,4,5},*r=a;   f(r);printf(”%d\n”;*r);   }   void f(int *p)   {p=p+3;printf(”%d,”,*p);}   程序运营后的输出结果是 A 1,4 B 4,4 C 3,1 D 4,1 答案:D 30. 有以下程序(函数fun只对下标为偶数的元素进行操作)   # include<stdio.h>   void fun(int*a;int n)   {int i、j、k、t;   for (i=0;i<n一1;1+=2)   {k=i;‘   for(j=i;ja〔k])k=j;   t=a〔i];a〔i]=a[k];a〔k]=t;   }   }   main()   {int aa「10」={1、2、3、4、5、6、7},i;   fun(aa、7);   for(i=0,i<7; i++)printf(”%d,”,aa[i]));   printf(”\n”);   }   程序运营后的输出结果是 A 7,2,5,4,3,6,1 B 1,6,3,4,5,2,7 C 7,6,5,4,3,2,1 D 1,7,3,5,6;2,1 答案:A 31. 下列选项中,可以满足“若字符串s1等于字符串s2,则执行ST"规定的是 A if(strcmp(s2,s1)==0)ST; B if(sl==s2)ST; C if(strcpy(s l ,s2)==1)ST; D if(sl-s2==0)ST; 答案:A 32. 以下不能将s所指字符串对的复制到t所指存储空间的是 A while(*t=*s){t++;s++;} B for(i=0;t[i]=s[i];i++); C do{*t++=*s++;}while(*s); D for(i=0,j=0;t[i++]=s[j++];); 答案:C 33. 有以下程序( strcat函数用以连接两个字符串)   #include<stdio.h>   #include<string .h>   main()   {char a[20]=”ABCD\OEFG\0”,b[]=”IJK”;   strcat(a,b);printf(”%s\n”,a);   }   程序运营后的输出结果是 A ABCDE\OFG\OIJK B ABCDIJK C IJK D EFGIJK 答案:B 34. 有以下程序,程序中库函数islower (ch)用以判断ch中的字母是否为小写字母   #include<stdio.h>   #include<ctype.h>   voidfun(char*p)   {inti=0;   while (p[i])   {if(p[i]==’ ’&& islower(p「i-1」))p[i-1]=p[i-1]-‘a’+‘A’;   i++;   }   }   main()   {char s1[100]=”ab cd EFG!”;   fun(s1); printf(”%s\n”,s1);   }   程序运营后的输出结果是 A abcdEFG! B AbCdEFg! C aBcDEFG! D abcdEFg! 答案:C 35. 有以下程序   #include<stdio.h>   voidfun(int x)   {if(x/2>1)fun(x/2);   printf(”%d”,x);   }   main()   {fun(7);printf(”\n”);}   程序运营后的输出结果是 A 1 3 7 B 7 3 1 C 7 3 D 3 7 答案:B 36. 有以下程序   #include<stdio.h>   int fun()   {static int x=1;   x+=1;return x;   }   main()   {int i;s=1;   for(i=1;i<=5;i++)s+=fun();   printf(”%d\n”,s);   }   程序运营后的输出结果是 A 11 B 21 C 6 D 120 答案:B 37. 有以下程序   #inctude<stdio.h>   #include<stdlib.h>   Main()   {int *a,*b,*c;   a=b=c=(int*)malloc(sizeof(int));   *a=1;*b=2,*c=3;   a=b;   printf(“%d,%d,%d\n”,*a,*b,*c);   }   程序运营后的输出结果是 A 3,3,3 B 2,2,3 C 1,2,3 D 1,1,3 答案:A 38. 有以下程序   #include<stdio.h>   main()   {int s,t,A=10;double B=6;   s=sizeof(A);t=sizeof(B);   printf(“%d,%d\n”,s,t);   }   在VC6平台上编译运营,程序运营后的输出结果是 A 2,4 B 4,4 C 4,8 D 10,6 答案:C 39. 若有以下语句   Typedef struct S   {int g; char h;}T;   以下叙述中对的的是 A 可用S定义结构体变量 B 可用T定义结构体变量 C S是struct类型的变量 D T是struct S类型的变量 答案:B 40. 有以下程序   #include<stdio.h>   main()   {short c=124;   c=c_______;   printf(“%d\n”、C);   }   若要使程序的运营结果为248,应在下划线处填入的是 A >>2 B |248 C &0248 D < 答案:C 二、填空题(每空2分,共30分)     请将每空的对的答案写在答题卡【1】至【15】序号的横线上,答在试卷上不得分。 1. 一个栈的初始状态为空。一方面将元素5,4,3,2,1依次入栈,然后退栈一次,再将元素 A,B,C,D依次入栈,之后将所有元素所有退栈,则所有元素退栈(涉及中间退栈的元素)的顺序为【1】 答案:1DCAB2345 2. 在长度为n的线性表中,寻找最大项至少需要比较【2】次。 答案:log2(n) 3. 一棵二叉树有10个度为1的结点,7个度为2的结点,则该二叉树共有【3】个结点。 答案:25 4. 仅由顺序、选择(分支)和反复(循环)结构构成的程序是【4】程序。 答案:结构化 5. 数据库设计的四个阶段是:需求分析,概念设计,逻辑设计【5】。 答案:物理设计 6. 以下程序运营后的输出结果是【6】。   #include<stdio.h>   main()   {int a=200,b=010;   printf(”%d%d\n”,a,b);   } 答案:2023 7. 有以下程序   #include<stdio.h>   main()   {intx,Y;   scanf(”%2d%ld”,&x,&y);printf(”%d\n”,x+y);   }   程序运营时输入:1234567程序的运营结果是【7】。 答案:3 8. 在C语言中,当表达式值为0时表达逻辑值“假”,当表达式值为【8】时表达逻辑值“真”。 答案:非0 9. 有以下程序   #include<stdio.h>   main()   {int i,n[]={0,0,0,0,0};   for (i=1;i<=4;i++)   {n[i]=n[i-1]*3+1; printf(”%d ",n[i]);}   }   程序运营后的输出结果是【9】。 答案:1 4 13 40 10. 以下fun函数的功能是:找出具有N个元素的一维数组中的最小值,并作为函数值返回。请填空。(设N已定义)   int fun(int x[N])   {int i,k=0;   for(i=0;i<N;I++)   if(x[i]   return x[k];   } 答案:i 11. 有以下程序   #include<stdio.h>   int*f(int *p,int*q);   main()   {int m=1,n=2,*r=&m;   r=f(r,&n);printf(”%d\n”,*r);   }   int*f(int *p,int*q)   {return(*p>*q)?p:q;}   程序运营后的输出结果是【11】 答案:2 12. 以下fun函数的功能是在N行M列的整形二维数组中,选出一个最大值作为函数值返回,请填空。(设M,. N已定义)   int fun(int a[N][M))   {int i,j,row=0,col=0;   for(i=0;i<N;I++)   for(j=0;j   if(a[i][j]>a[row][col]){row=i;col=j;}   return(【12】): 答案:a[row][col] 13. 有以下程序   #include<stdio.h>   main()   {intn[2],i,j;   for(i=0;i<2;i++)n[i]=0;   for(i=0;i<2;i++)   for(j=0;j<2;j++)n[j]=n「i」+1;   printf(”%d\n”,n[1]);   }   程序运营后的输出结果是【13】 答案:2 14. 以下程序的功能是:借助指针变量找出数组元素中最大值所在的位置并输出该最大值。请在输出语句中填写代表最大值的输出项。   #include<stdio.h>   main()   {int a〔10],*p,*s;   for(p=a;p-a<10;p++)scanf(”%d”,p);   for(p=a,s=a;p-a<10;p++)if(*p>*s)S=P;   printf("max=%d\n”,【14】);   } 答案:*s 15. 以下程序打开新文献f.txt,并调用字符输出函数将a数组中的字符写入其中,请填空。   #include<stdio.h>   main()   {【15】*fp;   char a[5]={’1’,’2’,’3’,’4’,’5’},i;   fp=fopen(”f .txt”,”w”);   for(i=0;i<5;i++)fputc(a[i],fp);   fclose(fp);   } 答案:FILE
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传
相似文档                                   自信AI助手自信AI助手

当前位置:首页 > 考试专区 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服