二级C语言真题及答案.docx

上传人:b****3 文档编号:13267128 上传时间:2023-06-12 格式:DOCX 页数:30 大小:46.99KB
下载 相关 举报
二级C语言真题及答案.docx_第1页
第1页 / 共30页
二级C语言真题及答案.docx_第2页
第2页 / 共30页
二级C语言真题及答案.docx_第3页
第3页 / 共30页
二级C语言真题及答案.docx_第4页
第4页 / 共30页
二级C语言真题及答案.docx_第5页
第5页 / 共30页
二级C语言真题及答案.docx_第6页
第6页 / 共30页
二级C语言真题及答案.docx_第7页
第7页 / 共30页
二级C语言真题及答案.docx_第8页
第8页 / 共30页
二级C语言真题及答案.docx_第9页
第9页 / 共30页
二级C语言真题及答案.docx_第10页
第10页 / 共30页
二级C语言真题及答案.docx_第11页
第11页 / 共30页
二级C语言真题及答案.docx_第12页
第12页 / 共30页
二级C语言真题及答案.docx_第13页
第13页 / 共30页
二级C语言真题及答案.docx_第14页
第14页 / 共30页
二级C语言真题及答案.docx_第15页
第15页 / 共30页
二级C语言真题及答案.docx_第16页
第16页 / 共30页
二级C语言真题及答案.docx_第17页
第17页 / 共30页
二级C语言真题及答案.docx_第18页
第18页 / 共30页
二级C语言真题及答案.docx_第19页
第19页 / 共30页
二级C语言真题及答案.docx_第20页
第20页 / 共30页
亲,该文档总共30页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

二级C语言真题及答案.docx

《二级C语言真题及答案.docx》由会员分享,可在线阅读,更多相关《二级C语言真题及答案.docx(30页珍藏版)》请在冰点文库上搜索。

二级C语言真题及答案.docx

二级C语言真题及答案

2007年9月二级C笔试试卷

一、选择题

下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。

(1)软件是指

A)程序B)程序和文档C)算法加数据结构D)程序、数据与相关文档的完整集合

(2)软件调试的目的是

A)发现错误B)改正错误C)改善软件的性能D)验证软件的正确性

(3)在面向对象方法中,实现信息隐蔽是依靠

A)对象的继承B)对象的多态C)对象的封装D)对象的分类

(4)下列叙述中,不符合良好程序设计风格要求的是

A)程序的效率第一,清晰第二B)程序的可读性好C)程序中要有必要的注释。

D)输入数据前要有提示信息

(5)下列叙述中正确的是

A)程序执行的效率与数据的存储结构密切相关B)程序执行的效率只取决于程序的控制结构

C)程序执行的效率只取决于所处理的数据量D)以上三种说法都不对

(6)下列叙述中正确的是

A)数据的逻辑结构与存储结构必定是一一对应的B)由于计算机存储空间是向量式的存储结构,因此,数据的存储结构一定是线性结构C)程序设计语言中的数组一般是顺序存储结构,因此,利用数组只能处理线性结构

D)以上三种说法都不对

(7)冒泡排序在最坏情况下的比较次数是

A)n(n+1)/2B)nlog2nC)n(n-1)/2D)n/2

(8)一棵二叉树中共有70个叶子结点与80个度为1的结点,则该二叉树中的总结点数为

A)219B)221C)229D)231

(9)下列叙述中正确的是

A)数据库系统是一个独立的系统,不需要操作系统的支持B)数据库技术的根本目标是要解决数据的共享问题

C)数据库管理系统就是数据库系统D)以上三种说法都不对

(10)下列叙述中正确的是

A)为了建立一个关系,首先要构造数据的逻辑关系B)表示关系的二维表中各元组的每一个分量还可以分成若干数据项

C)一个关系的属性名表称为关系模式D)一个关系可以包括多个二维表

(11)C语言源程序名的后缀是

A).exeB).CC).objD).cp

(12)可在C程序中用作用户标识符的一组标识符是

A)and_2007

B)Datey-m-d

C)HiDf.Tom

D)caseBig1

(13)以下选项中,合法的—组C语言数值常量是

A)028.5e-3-Oxf

B)120Xa234.5e0

C)1774e1.50abc

D)0x8A10,0003.e5

(14)以下叙述中正确的是

A)C语言程序将从源程序中第一个函数开始执行B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行C)C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束

D)main可作为用户标识符,用以命名任意一个函数作为主函数

(15)若在定义语句:

inta,b,c,*p=&c;之后,接着执行以下选项中的语句,则能正确执行的语句是

A)scanf("%d",a,b,c);B)scanf("%d%d%d",a,b,c);C)scanf("%d",p);D)scanf("%d",&p);

(16)以下关于long、int和short类型数据占用内存大小的叙述中正确的是

A)均占4个字节B)根据数据的大小来决定所占内存的字节数C)由用户自己定义D)由C语言编译系统决定

(17)若变量均已正确定义并赋值,以下合法的C语言赋值语句是

A)x=y==5;B)x=n%2.5;C)x+n=i;D)x=5=4+1;

(18)有以下程序段

intj;floaty;charname[50];

scanf("%2d%f%s",&j,&y,name);

当执行上述程序段,从键盘上输入555667777abc后,y的值为

A)55566.0B)566.0C)7777.0D)566777.0

(19)若变量已正确定义,有以下程序段i=0;

doPnntf("%d,",i);while(i++);

printf("%d\n",i);其输出结果是

A)0,0B)0,1C)1,1D)程序进入无限循环

(20)有以下计算公式

若程序前面已在命令行中包含math.h文件,不能够正确计算上述公式的程序段是

A)if(x>=0y=sqrt(x);elsey=sqrt(-x);

B)y=sqrt(x)if(x<0)y=sqrt(-x);

C)if(x>=0)y=sqrt(x);if(x<0)y=sqrt(-x)

D)y=sqrt(x>=0?

x:

-x);

(21)设有条件表达式:

(EXP)?

i++:

j--,则以下表达式中与(E)(P)完全等价的是

A)(EXP==0)B)(EXP!

=0)C)(EXP=-1)D)(EXP!

=1)

(22)有以下程序

#include<stdio.h>

main(){inty=9;

for(;y>0;y--)

if(y%3==0)printf("%d",--y);}程序的运行结果是

A)741B)963C)852D)875421

(23)已有定义:

charc;,程序前面已在命令行中包含ctype.h文件。

不能用于判断c中的字符是否为大写字母的表达式是

A)isupper(c)B)'A'<=c<='Z'C)'A'<=c&&c<='Z'D)c<=('z'-32)&&('a'-32)<=c

(24)有以下程序

#include<stdio.h>

main(){inti,j,m=55;

for(i=1;i<=3;i++)for(j=3;j<=i;j++)m=m%j;

printf("%d\n",m);}程序的运行结果是

A)0B)1C)2D)3

(25)若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是

A)函数的实参和其对应的形参共占同一存储单元B)形参只是形式上的存在,不占用具体存储单元

C)同名的实参和形参占同一存储单元D)函数的形参和实参分别占用不同的存储单元

(26)已知字符'A'的ASCII代码值是65,字符变量c1的值是'A',c2的值是'D'。

执行语句printf("%d,%d",c1,c2-2);后,输出结果是

A)A,BB)A,68C)65,66D)65,68

(27)以下叙述中错误的是

A)改变函数形参的值,不会改变对应实参的值B)函数可以返回地址值

C)可以给指针变量赋一个整数作为地址值D)当在程序的开头包含头文件stdio.h时,可以给指针变量赋NULL

(28)以下正确的字符串常量是

A)"\\\"B)'abc'C)OlympicGamesD)""

(29)设有定义:

charp[]={'1','2','3'},*q=p;,以下不能计算出一个char型数据所占字节数的表达式是

A)sizeof(p)B)sizeof(char)C)sizeof(*q)D)sizeof(p[0])

(30)有以下函数

intaaa(char*s){char*t=s;

while(*t++);

t--;return(t-s);}以下关于aaa函数的功能的叙述正确的是

A)求字符串s的长度B)比较两个串的大小C)将串s复制到串tD)求字符串s所占字节数

(31)若有定义语句:

inta[3][6];,按在内存中的存放顺序,a数组的第10个元素是

A)a[0][4]B)a[1][3]C)a[0][3]D)a[1][4]

(32)有以下程序

#include<stdio.h>

voidfun(char**p){++p;printf("%s\n",*p);}

main(){char*a[]={"Moming","Afternoon","Evening","Night"};

fun(a);}程序的运行结果是

A)AfternoonB)fternoonC)MorningD)orning

(33)若有定义语句:

inta[2][3],*p[3],则以下语句中正确的是

A)p=a;B)p[0]=a;C)p[0]=&a[1][2];D)p[1]=&a;

(34)有以下程序

#include<stdio.h>

voidfun(int*a,intn)/*fun函数的功能是将a所指数组元素从大到小排序*/{intt,i,j;

for(i=0;i<n-1;i++)for0=i+l;j<n;j++)

if(a[i]<a[j]){t=a[i];a[i]=a[j];a[j]=t;}}

main(){intc[10]={1,2,3,4,5,6,7,8,9,0},i;

fun(c+4,6);for(i=0;i<10;i++)printf("%d,",c[i]);

printf("\n");}

A)1,2,3,4,5,6,7,8,9,0,B)0,9,8,7,6,5,1,2,3,4,C)0,9,8,7,6,5,4,3,2,1,D)1,2,3,4,9,8,7,6,5,0,

(35)有以下程序

#include<stdio.h>

intfun(chars[]){intn=O;

while(*s<='9'&&*s>='0'){n=10*n+*s-'0';s++;}

return(n);}

main(){chars[10]={'6','1','*','4','*','9','*','0','*'};

printf("%d\n",fun(s));}

A)9B)61490C)61D)5

(36)当用户要求输入的字符串中含有空格时,应使用的输入函数是

A)scanf()B)getchar()C)gets()D)getc()

(37)以下关于字符串的叙述中正确的是

A)C语言中有字符串类型的常量和变量B)两个字符串中的字符个数相同时才能进行字符串大小的比较

C)可以用关系运算符对字符串的大小进行比较D)空串一定比空格打头的字符串小

(38)有以下程序

#include<stdio.h>

voidfun(char*t,char*s){while(*t!

=0)t++;

while((*t++=*s++)!

=0);

main(){charss[10]="acc",aa[10]="bbxxyy";

fun(ss,aa);printff"%s,%s\n",ss,aa);程序的运行结果是

A)accxyy,bbxxyyB)acc,bbxxyyC)accxxyy,bbxxyyD)accbbxxyy,bbxxyy

(39)有以下程序

#include<stdio.h>

#include<string.h>

voidfun(chars[][10],intn){chart;intij;

for(i=0;i<n-1;i++)for0--i+l;j<n;j++)

/*比较字符串的首字符大小,并交换字符串的首字符*/

if(s[i][0]>s[j][0]){t=s[i][0];s[i][0]=s[j][0];s[j][0]=t;}}

main(){charss[5][10]={"bcc","bbcc","xy","aaaacc","aabcc"};

fun(ss,5);printf("%s,%s\n",ss[0],ss[4]);}

程序的运行结果是

A)xy,aaaaccB)aaaacc,xyC)xcc,aabccD)acc,xabcc

(40)在一个C源程序文件中所定义的全局变量,其作用域为

A)所在文件的全部范围B)所在程序的全部范围C)所在函数的全部范围D)由具体定义位置和extern说明来决定范围

(41)有以下程序

#include<stdio.h>

inta=1;

intf(intc){staticinta=2;

c=c+1;return(a++)+c;}

main(){inti,k=0;

for(i=0;i<2;i++){inta=3;k+=f(a);

k+=a;printf("%d\n",k);}

A)14B)15C)16D)17

(42)有以下程序#include<stdio.h>

voidfun(intn,int*p){intf1,t2;

if(n==1||n==2)*p=1;else{fun(n-1,&f1);fun(n-2,&f2);

*p=f1+f2;

}}

main(){ints;

fun(3,&s);printf("%d\n",s);}

A)2B)3C)4D)5

(43)若程序中有宏定义行:

#defineN100则以下叙述中正确的是

A)宏定义行中定义了标识符N的值为整数100B)在编译程序对C源程序进行预处理时用100替换标识符N

C)对C源程序进行编译时用100替换标识符ND)在运行时用100替换标识符N

(44)以下关于typedef的叙述错误的是

A)用typedef可以增加新类型B)typedef只是将已存在的类型用一个新的名字来代表

C)用typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名D)用typedef为类型说明一个新名,通常可以增加程序的可读性

(45)有以下程序

#include<stdio.h>

structtt{intx;structtt*y;}*p;

structtta[4]={20,a+1,15,a+2,30,a+3,17,a};

main(){inti;p=a;

for(i=1;i<-2;i++){printf("%d,",p->x);p=p->y;}

A)20,30,B)30,17C)15,30,D)20,15,

(46)有以下程序

#include<stdio.h>

#include<string.h>

typedefstruct{charname[9];charsex;floatscore[2];}STU;STUf(STUa)

{STUb={"Zhao",'m',85.0,90.0};inti;

strcpy(a.name,b.name);a.sex=b.sex;

for(i=0;i<2;i++)a.score[i]=b.score[i];returna;}

main(){STUc={"Qian",T,95.0,92.0},d;

d=f(c);printf("%s,%c,%2.0f,%2.0f\n",d.name,&sex,&score[O],d.score[1]);}程序的运行结果是

A)Qian,f,95,92B)Qian,m,85,90C)Zhao,m,85,90D)Zhao,f,95,92

(47)设有以下定义

uniondata{intd1;floatd2;}demo;则下面叙述中错误的是

A)变量demo与成员d2所占的内存字节数相同B)变量demo中各成员的地址相同

C)变量demo和各成员的地址相同D)若给demo.d1赋99后,demo.d2中的值是99.0

(48)有以下程序

#include<stdio.h>

main(){inta=1,b=2,c=3,x;

x=(a^b)&c;printf("%d\n",x)}程序的运行结果是

A)0B)1C)2D)3

(49)读取二进制文件的函数调用形式为:

fread(buffer,size,count,fp);,其中buffer代表的是

A)一个文件指针,指向待读取的文件B)一个整型变量,代表待读取的数据的字节数

C)一个内存块的首地址,代表读入数据存放的地址D)—个内存块的字节数

(50)有以下程序

#include<stdio.h>

main(){FILE*fp;int'a[10]={1,2,3,0,0},i;

fp=fopen("d2.dat","wb");fwrite(a,sizeof(int),5,fp);

fwrite(a,sizeof(int),5,fp);

fclose(fp);

fp=fopenCd2.dat","rb");fread(a,sizeof(int),10,fp);

fclose(fp);

for(i=0;i<10;i++)printf("%d,",a[i]);}

A)1,2,3,0,0,0,0,0,0,0,B)1,2,3,1,2,3,0,0,0,0,C)123,0,0,0,0,123,0,0,0,0,D)1,2,3,0,0,1,2,3,0,0,

(1)软件需求规格说明书应具有完整性、无歧义性、正确性、可验证性、可修改性等特性,其中最重要的是【1】。

(2)在两种基本测试方法中,【2】测试的原则之一是保证所测模块中每一个独立路径至少要执行一次。

(3)线性表的存储结构主要分为顺序存储结构和链式存储结构。

队列是一种特殊的线性表,循环队列是队列的【3】存储结构。

(4)对下列二叉树进行中序遍历的结果为【4】。

(5)在E-R图中,矩形表示【5】。

(6)执行以下程序时输入1234567<CR>,则输出结果是【6】。

#include<stdio.h>

main(){inta=1,b;

scanf("%2d%2d",&a,&b);prinff("%d%dhn",a,b);}

(7)以下程序的功能是:

输出a、b、c三个变量中的最小值。

#include<stdio.h>

main(){inta,b,c,t1,t2;scanf("%d%d%d",&a,&b,&c);

t1=a<b?

【7】;

t2=c<t1?

【8】;printf("%d\n",t2);}

(8)以下程序的输出结果是【9】。

#include<stdio.h>

main(){intn=12345,d;

while(n!

=O){d=n%10;printf("%d",d);n/=10;}

(9)有以下程序段,且变量已正确定义和赋值

for(s=1.0,k=1;k<=;k++)s=s+1.0/(k*(k+1));printf("s=%f\n\n",s);

请填空,使下面程序段的功能与之完全相同

s=1.0;k=1;

while(【10】){s=s+1.0/(k*(k+1));【11】;}prinff("s=%f\n'n",s);

(10)以下程序的输出结果是【12】。

#include<stdio.h>

main(){inti;

for(i='a';i<'f';i++,i++)printf("%c",i-'a'+'A');

printf("\n")}(11)以下程序的输出结果是【13】。

#include<stdio.h>

#include<string.h>

char*fun(char*0{char*p--t;

return(p+strlen(t)/2);}

main(){char*str="abcdefgh";

str=ftm(str);puts(str);}

(12)以下程序中函数f的功能是在数组x的n个数(假定n个数互不相同)中找出最大最小数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。

请填空。

#include<stdio.h>

voidf(intx[],intn){intp0,p1,i,j,t,m;

i=j=x[O];p0=p1=O;

for(m=0;m<n;m++)

{if(x[m]>i){i=x[m];p0=m;}

elseif(x[m]<j){j=x[m];p1=m;}}

t=x[p0];x[p0]=x[n-1];x[n-1]=t;

t=x[p1];x[p1]=【14】;【15】=t;}

main(){inta[10],u;

for(u=O;u<10;u++)scanf("%d",&a[u]);f(a,10);

for(u=O;u<10;u++)printf("%d",a[u]);printf("\n");}

(13)以下程序统计从终端输入的字符中大写字母的个数,num[0]中统计字母A的个数,num[1]中统计字母B的个数,其他依次类推。

用#号结束输入,请填空。

#include<stdio.h>

#include<ctype.h>

main(){intnum[26]={0},i;charc;while((【16】)!

='#')

if(isupper(c))hum[c-'A']+=【17】;

for(i=0;i<26;i++)printf("%c:

%d\n",i+'A',num[i]);

(14)执行以下程序的输出结果是【18】。

#include<stdio.h>

main()[inti,n[4]={1};

for(i=1;i<=3;i++)

{n[i]=n[i-1]*2+1;printf("%d",n[i]);}

(15)以下程序的输出结果是【19】。

#include<stdio.h>

#defineM5

#defineNM+M

main0{intk;

k=N'N*5;printf("%d\n",k);}

(16)函数min()的功能是:

在带头结点的单链表中

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 医药卫生 > 基础医学

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2