全国计算机等历考试二C语言真题9.docx

上传人:b****1 文档编号:3329662 上传时间:2023-05-05 格式:DOCX 页数:20 大小:32.07KB
下载 相关 举报
全国计算机等历考试二C语言真题9.docx_第1页
第1页 / 共20页
全国计算机等历考试二C语言真题9.docx_第2页
第2页 / 共20页
全国计算机等历考试二C语言真题9.docx_第3页
第3页 / 共20页
全国计算机等历考试二C语言真题9.docx_第4页
第4页 / 共20页
全国计算机等历考试二C语言真题9.docx_第5页
第5页 / 共20页
全国计算机等历考试二C语言真题9.docx_第6页
第6页 / 共20页
全国计算机等历考试二C语言真题9.docx_第7页
第7页 / 共20页
全国计算机等历考试二C语言真题9.docx_第8页
第8页 / 共20页
全国计算机等历考试二C语言真题9.docx_第9页
第9页 / 共20页
全国计算机等历考试二C语言真题9.docx_第10页
第10页 / 共20页
全国计算机等历考试二C语言真题9.docx_第11页
第11页 / 共20页
全国计算机等历考试二C语言真题9.docx_第12页
第12页 / 共20页
全国计算机等历考试二C语言真题9.docx_第13页
第13页 / 共20页
全国计算机等历考试二C语言真题9.docx_第14页
第14页 / 共20页
全国计算机等历考试二C语言真题9.docx_第15页
第15页 / 共20页
全国计算机等历考试二C语言真题9.docx_第16页
第16页 / 共20页
全国计算机等历考试二C语言真题9.docx_第17页
第17页 / 共20页
全国计算机等历考试二C语言真题9.docx_第18页
第18页 / 共20页
全国计算机等历考试二C语言真题9.docx_第19页
第19页 / 共20页
全国计算机等历考试二C语言真题9.docx_第20页
第20页 / 共20页
亲,该文档总共20页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

全国计算机等历考试二C语言真题9.docx

《全国计算机等历考试二C语言真题9.docx》由会员分享,可在线阅读,更多相关《全国计算机等历考试二C语言真题9.docx(20页珍藏版)》请在冰点文库上搜索。

全国计算机等历考试二C语言真题9.docx

全国计算机等历考试二C语言真题9

2007年9月全国计算机等级考试二级笔试试卷

C语言程序设计

<考试时间120分钟,满分100分)

一、选择题<<1)——<10)每题2分,<11)—<50)每题1分,共60分)

下列各题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)andB)DateC)HiD)case

2007y-m-dDr.TomBigl

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

A)028B)12C)177D)0x8A

.5e-3OXa234c1.510,000

<14)以下叙述正确的是

A)C语言程序将从源程序中第一个函数开始执行

B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行

C)C语言规定必须用min作为主函数名,程序将从开始执行,在此结束

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

<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=l;D)x=5=4+1

<18)有以下程序段

intj;floaty;charname[50];

scanf(“%2d%f%s”,&j,&y,name>

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

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

<19)若变量已正确定义,有以下程序段

i=0;

doprintf(“%d,”i>;while(i++>;

printf(“%d\n”,i>;

其输出结果是

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

<20)有以下计算公式

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

A)if(x>=0>y=sprt(x>。

B)y=sqrt(x>。

elsey=sqrt(-x>。

if(x<0>y=sqrt(x>

C)if(x>=0>y=sqrt(x>。

D)y=sqrt(x>0?

x。

-x>

If(x<0>y=sqrt(-x>。

<21)设有条件表达式:

(EXP>?

i++。

j—,则以下表达式中与

A)

=0)C)

=1)

<22)有以下程序

#include

main(>

﹛infy=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)有以下程序

#includc

Main(>

﹛inti,j,m=55

for(i=l。

i<3。

i++>

for(j=3。

j<=++>m=m%j;

printf(“%d\n”,m>。

程序的运行结果是

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

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

A)函数的实参和其对应的形参共占用一存储单元

B)形参只是形式上的存在,不占用具体存储单元

C)同名的实参和形参占同一存储单元

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

<26)已知字符‘A’的ASCII代码值是65,字符变量cl的值的‘A’,c2的值是‘D’。

执行语句

printf(“%d,%d”,cl,c2-2>;后,输出结果是

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

<27)以下途述中错误的是

A)改变函数形参的值,不会改变对应实参的值

B)函数可以返回地址值

C)可以给指针变量赋一个整数作为地址值

D)当在程序的开头包含文件stdio.h时,可以给指针变量赋NULL

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

A)“╲╲╲”B)‘abc’C)OlympicD>**

<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

voidfun(char**p>

{++p。

printf(“%”﹨n”,*p>。

}

main(>

{char*a[]={“Moming”,“Aftenoon”,“Evening”,“Night”};

fun(a>

}

程序的运行结果是

A)AftemoonB)ftemoonC)MomingD)oming

<33)若有定义语句:

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

A)p=a。

B>p[0]=a。

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

<34)有以下程序

#include

voidfun(int*a,intn>/*fun函数的功能是将a所指数组元数从大到小排序*/

{intt,i,j。

for(i=o。

i

j++>

for(j=j+1。

j

j++>

if(a[i]{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

intfun(chars[]>

{intn=0。

while(*s<=‘9’&&*s>=‘0’>{n=[0*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)getsD)getc(>

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

A)C语言中有字符串类型的常量和变量

B)两个字符串中的字符个数相同时才能进行字符串大小的比较

C)可以用关系运算符对字符串的大小进行比较

D)空串一定比空格打头的字符串小

<38)有以下程序

#include

voidfun(char*t,char*s>

{while(*t!

=0>t++。

while{(*t++=*s++>!

=0}。

}

min(>

{charss[10]=“acc”,aa[10]=“bbxxyy”。

fun(ss,aa>。

printf(“%s,%s﹨n”,ss,aa>。

}

程序的运行结果是

A)accxyy,bbxxyyB)axx,bbxxyy

C)accxxyy,bbxxyyD)accbbxxyy,bbxxyy

<39)有以下程序

#include

#include

voidfun(chars[][10],intn>

{chart。

intij。

for(i=0。

i

i++>

for(j=i+1。

j

j++>

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

if(s[i][0]>s[j][0]>{l=s[i][0]。

s[i][0]。

s[j][0]=t。

}

}

main(>

{charss[5][10]={“bcc”,“bbcc”,“xy”,“aaaacc”,“aabbc”}。

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)由具体定义位置和extrn说明来决定范围

<41)有以下程序

#includc

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<15)C)16D)17

<42)有以下程序

#include

voidfun(intn,int*p>

{intf1,f2。

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”>。

}

程序的运行结果是

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

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

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

A)宏定义行中定义了标识符N的值为整数100

B)在编译程序对C源程序进行预处理时用100替换标识符N

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

D)在运行时用100替换标识符N

<44)以下关于typedef的途述错误的是

A)用typedef可以增加新类型

B)typedef是将已存在的类型用一个新的名字来代表

C)用typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名

D)用typedef为类型说明一个新名,通常可以增加程序的可读性

<45)有以下程序

#include

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,17C15,30,D)20,15

<46)有以下程序

#include

#include

Typedefstructcharname[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]。

retuma。

}

main(>

{STUc={“Qian”,‘f’,95.0,92.0}d。

d=f(c>。

printf(“%s,%c,%2.of,%2.of﹨n”,d.name,d.sex,d.score[0].d,score[1]>。

}

程序的运行结果是

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

<47)设有以下定义

Uniondata

{intdl。

floatd2。

}demo。

则下面叙述中错误的是

A)变量demo与成员d2所占的内存字节数相同

B)变量demo中各成员的地址相同

C)变量demo和各成员的地址相同

D)若给demo.d1赋99后,demo.d2中的值是99.0

<48)有以下程序

#include

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

Main(>

{FILE*fp。

inta[10]={1,2,3,0,0},i。

fp=fopen(“d2.dat”.”wb”>

fwrite(a,sizeof(int>,5,fp>

fwrite(a,sizeof(int>,5,fpj>。

fclose(fp>。

fp=fopen(“d2.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,0B)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.

二、填空题<每空2分,共40分)

请将每一个空的正确答案写在答题卡[1]至[20]序号的横线上,答在试卷上不得分。

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

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

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

队列是一种特殊的线性表。

循环队列是队列的存储结构。

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

 

<5)在E-R图中,矩形表示。

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

#include

Main(>

{inta=1,b。

Scanf(“%2d%2d”,&a,&b>。

printf(“%d%d\n”,a,b>

}

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

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

请填空。

#include

Main(>

{inta,b,c,t1,t2。

Scanf(*%d%d%d”,&a,&b,&c>。

t1=a

t2=c<1?

printf(“%d\n”,t2>。

<8)以下程序的输出结果是。

#include

Main(>

{intn=12345,d。

while(n!

=0>{d=n%10。

printf(“%d”,d>。

n/=10。

}

}

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

for(S=1.0,k=1。

k<=n。

k++>s=s+1.0/(k*(k+>>。

printf(“S=%f\n\n”,s>。

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

S=1.0。

k=1。

While(>{s=s+1.0/(k*(k+1>>。

}

Printf(“s=%f\n\n”,s>。

<10)以下程序的输出结果是。

#include

main(>

{inti。

for(i=a。

j

i++,i++>printf(“%c”,i-‘a’+’A’>。

printf(“\n”>。

}

<11)以下程序的输出结果是。

#include

#include

Char*fun(char*t>

{char*p=t。

retrun(p+strlen(t>/2>。

}

main(>

{char*str=”abcdefgh”。

str=fun(str>。

puts(str>。

}

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

请填空。

#include

voidf(intx[],intn>

{intp0,p1,i,j,t,m。

i=j=x[0]。

p0=p1=0。

for(m=0。

m

m++>

{if(x[m]>i>{i=x[m]。

p0=m。

}

Elseif(x[m]{j=x[m]。

p1=m。

}

}

t=x[p0]。

x[p0]=x[n-1]。

x[n-1]=1。

t=x[p1]。

x[p1]=。

=t。

}

main(>

{inta[10],u。

for(u=0。

u<10。

u++>scanf(*%d,&a[u]>。

f(a,10>。

for(u=0。

u<10。

u++>printf(“%d”,a[u]>。

printf(“\n”>。

}

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

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

#include

#include

main(>

{intnum[26]={0},i。

charc。

while(>!

=”#”>

if(isupper(c>>num[c-‘A’]+=。

for(i=0。

i<26。

i++>

printf(*%c。

%d\n”,i+’A’,num[i]>。

}

<14)执行以下程序的输出结果是。

#include

main(>

{inti,n[4]={1}。

For(i=1。

i<=3。

i++>

{n[i]=n[i-1]*2+1。

printf(”%d”,n[i]>。

}

}

<15)以下程序的输出结果是。

#include

#defineM5

#defineNM+M

main(>

{intk。

K=N*N*5。

printf(“%d\n”,k>。

}

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

在带头结点的单链表中查找数据域中值最小的结点。

请填空

#include

Structnode

{intiata。

Structnode*next。

}。

Intmin(structnode*first>/*批针first为链表头指针*/

{structnod*p。

intm。

P=first->next。

m=p->data。

p=p->next。

for(。

p!

=NULL。

p=>

if(p->datam=p->data。

retumm。

}

2007年9月全国计算机等级考试二级C语言笔试参考答案

一、选择题

1~5DBCAA 

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

当前位置:首页 > IT计算机 > 电脑基础知识

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

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